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Tym razem zacznę nietypowo - od końca. Jest to jednak w 
pełni usprawiedliwione, gdyż moim zdaniem najatrakcyjniej¬ 
sze teksty tego numeru zawiera blok W pracy. Nie chciałbym 
zapeszyć, ale gratuluję nowemu kierownikowi działu oprogra¬ 
mowania. Początek całkiem obiecujący! 


W pierwszej kolejności polecłc naiezy maieriai pCaWięccrr/ 
pakietowi zarządzania relacyjnymi bazami danych dBase IV. 
Nowy produkt firmy Ashton Tatę jest niewątpliwie wydarze¬ 
niem ostatnich miesięcy i z ogromnym zainteresowaniem ocze¬ 
kiwany był także na naszym rynku. Z pierwszych doświadczeń 
wynika, że towarzyszący oczekiwaniom sceptycyzm okazał się 
nieuzasadniony. Więcej, autorzy zamieszczanego przez nas 
opisu uważają, że jest to program tworzący nową jakość, dający 
znacznie większe możliwości niż dotychczasowe. 

Kolejnym tekstem w tej części numeru zasługującym na uwa¬ 
gę jest pierwszy fragment opracowania poświęconego syste¬ 
mom ekspertowym. Na pytanie: Co to są systemy ekspertowe? 
zapewne potrafilibyśmy coś odowiedzieć. W każdym razie po¬ 
jęcie nie jest zupełnie obce. Kłopot zaczyna się w momencie, 
gdy trzeba powiedzieć coś więcej niż tylko ogólniki. Tomasz 
Zieliński podjął próbę przybliżenia tej tematyki w sposób w 
miarę zrozumiały dla większości użytkowników mikrokompu¬ 
terów. 

Myślę, że Czytelników zajmujących się sieciami komputero¬ 
wymi zainteresuje artykuł Pascal i wielozadaniowość. Autor 
przedstawia konkretną propozycję tworzenia wielodostęp¬ 
nych programów w Pascalu, przy bardzo oszczędnej gospo¬ 
darce pamięcią operacyjną komputera. 

Bardzo modnym i zarazem nieprzyjemnym tematem w świa¬ 
tku bitów i bajtów są ostatnio wirusy. Tym już poszkodowanym 
i tym, którzy z drżeniem serca uruchamiają nowe programy po¬ 
lecam Przeciwciała w systemie komputerowym - obszerne 
opracowanie przygotowane przez Macieja Borkowskiego w 
oparciu o zachodnioniemiecki ”Chip”. 

Kończąc omawianie bloku W pracy odnotuję powrót na na¬ 
sze łamy Jakuba Tatarkiewicza (mamy nadzieję, że wrócił na 
stałe). 

A co znajdą Państwo w pozostałej części pisma? Przede 
wszystkim zasygnalizuję kolejne osiągnięcie medycyny ludo¬ 
wej. Dzięki intensywnej, pełnej poświęcenia pracy kolegów z 
redakcji oraz wytrwałości i uporowi Autorów z Krakowa udało 
się reanimować Komputer dla medyka. Sukces jest tym więk¬ 
szy, że cykl ten od początku nie miał szczęścia. Miejmy nadzie¬ 
ję, że teraz będzie łatwiej. 

Podobnym optymizmem napawa pojawienie się znowu ru¬ 
bryki Poke n, oo - cieszącej się niegdyś dużym powodzeniem. 

I jeszcze dwa materiały ze Wschodu. O Dalekim traktuje roz¬ 
mowa zatytułowana £SS£X w Singapurze, o tym najbliższym - 
reportaż W jaskini hazardu (komputerowego). 

Życzę przyjemnej lektury. 

Stanisław Marek Królak 
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Różnie już pisano o zjawach, duchach i widmach. Ostatnio (i nie tylko 
ostatnio) modne jest widmo, które kręży po Europie. Z czasów pobierania 
nauk, wówczas zwanych pohtycznymi, a dziś diabli wiedzą jak, pamiętam, 
że widmo owo było komunizmem. Dziś, o dziwo, występuje w tej samej 
postaci, ale jako widmo upadku koszarowego komunizmu. Wyczytałem 
to w drugim numerze "Gazety wyborczej" Solidarności i teraz się zastana¬ 
wiam, czy chodzi tu o to samo, czy też może w chwili pisania pierwszego 
i drugiego tekstu jeszcze nie było wiadomo, jakie to właściwie widmo krą¬ 
ży po Europie. Ale te moje polityczne wspominki niezbyt są świeże w 
chwili ich druku, a przyczyny i rozterki miotające autorem bardzo klarow¬ 
nie wyjaśnia Grzegorz Eider w atrykule obok. 

Ale miało być o duchu, a nie o widmie, choć oba zjawiska są spokrew¬ 
nione nie tylko w literaturze, ale i w życiu. 

Rzecz jest o DUCHU KOMPUTERYZACJI. 

Gdzieś TY, DUCHU, gdzie? Jeszcze rok temu wydawało się, że zapano¬ 
wałeś bezkonkiurencyjnie w naszym przaśnym kraju, a dziś? 

Dziś znowu skrzeczy pospolitość, kryzys, inflacja i inne plagi - do wy¬ 
boru. DUCH KOMPUTERYZACJI wyposażył co prawda nasze biura, pra¬ 
cownie i Ważne Urzędy w komputery (większości klasy PC/XT), ale nie¬ 
stety nie dał wskazówek, co dalej. No i efekty tego widzimy. Otrzymujemy 
paski wypłat, w których coraz bardzie zatarte są, drukowane na drukarce 
bez nasączonej tuszem taśmy, cyfry. Szczęśliwcy, którzy mają telefon w 
domu, dostają rachunki, w których udało się zastąpić literę Ł znakiem bry¬ 
tyjskiego funta, innych "polskich" hter niestety nie udało się niczym zastą¬ 
pić. Poważne wydawnictwa bez żadnego skrępowania kierują do sprze¬ 
daży powielone w kilku lub kilkudziesięciu tysiącach egzemplarzy zwy¬ 
czajne wydruki z 9-igłowej drukarki, formowane za pomocą prymitywne¬ 
go edytora tekstu i nazywają takie dzieło KSIĄŻKĄ! Mniejsza już o (bardzo 
wysoką) cenę. W telewizji (z małymi i chwałebnymi wyjątkami) plansze 
"komputerowe” zapowiedzi programowych, a nawet poważnych progra¬ 
mów promujących najnowsze osiągnięcia techniki atakują naszą wyobra¬ 
źnię plastyczną - obrazkami do złudzenia przypominającymi osiągnięcia 
"Spectrum". I rzeczywiście! Właśnie za pomocą tego komputera są produ¬ 
kowane! To samo szczyt techniki: tełegazeta, do jej odbioru potrzebne są 
specjalnie przystosowane odbiorniki TV, a najlepiej fabrycznie przygoto¬ 
wanych na taką okropną ewentualność. Dla porządku dodać należy, że tu 
i ówdzie,(szczególnie ówdzie) jest to po prostu standard każdego odbio- 
nika TV. Jednak pragnę uprzedzić ewentualne sprostowania, tele-gazeta 
być może robiona jest za pomocą "Meritum". 

Z innej łączki - Bardzo Ważny, i co najbardziej istotne. Bardzo Duży Za¬ 
kład Przemysłu Co Pan Wiesz, A Ja Rozumiem, czyli po prostu 
BWIBDZPCPWAJR, wprowadza system: kadry (20 tys. pracowników), fi¬ 
nanse, gospodraka (uwaga korekta! właśnie tak ma być, w nawiązaniu do 
sławnej ongiś pomyłki korektorskiej w dimku przemówienia 'Wiesława, 
wówczas był jeszcze przymiotnik "socjałistyczna”) materiałowa i kiłka in¬ 
nych. DUCH KOMPUTERYZACJI ostanim tchnieniem podpowiedział, że 
na XT nie da rady. Triumfalnie zakupiono wówczas AT z twardym dys¬ 
kiem 20 Mega i fajno jest! 

Gdzie jesteś, DUCHU komputeryzacji? Poradź, czy trzeba specjalistów 
z owego zakładu wbić na pal, uprzednio gotując ich w oleju, czy też może 
jest jakieś usprawiedliwienie? 

Gdzieżeś Ty, nasz ulubiony DUCHU? Poradź, co robić, aby, jak to trafnie 
ujmuje nasz szef graficzny - Stefan Szczypka, dalej rozwijać cywilizację 
BIAŁEGO człowieka, w odróżnieniu od cywilizacji człowieka szarego. 

Co robić, by uzyskać odpowiedz na pytanie (z naszego podwórka), czy 
opłaca się wysyłać do drukarni gotowiuteńkie kolumny tylko do naświet¬ 
lenia i od razu do druku? (odpowiedź na końcu pisaniny). 

Być może pytania do DUCHA KOMPUTERYZACJI są zbyt trudne. Oś¬ 
mielę się więc na kilka podpowiedzi szeptem. Ciii...Cicho!!!. Wiem, że wy¬ 
dawnictwa i TV są bardzo biedne (to z kolei jest dziś modne). Uważam je¬ 
dnak, że jeżeli zrezygnujemy całkowicie z pewnych wypracowanych 
przez wieki cywilizacyjnych standardów, to będzie nie tylko wstyd, ale 
dobrowolne i niestety przez ludzi bez wyobraźni lansowane, zepchnięcie 
się na takie dno, do którego nikt już od spodu nie .stuka, Godny pochwały 
zapał, który niewątpliwie przewodził poczynaniom zapalpnrow tworzą¬ 
cych tele-gazetę, wprowadzenie komputerów do przedsiębiorstwa czy 
szybkie wydanie książki dziś MUSI zostać zastąpione chłodnym profesjo¬ 


nalizmem. Przy niewątpliwych korzyściach, jakie dają komputery, po pro¬ 
stu trzeba zainwestować w sprzęt i programy dające możliwość działania 
na jakim-takim poziomie. Jest niestety także prawdą, że właściwie niespo- 
sób nabyć w naszym pięknym kraju minikomnmer, nie wspominając o 
całkiem dużym. 

Z tego wszystkiego wynika wniosek, że po dobrym początku nauki 
pierwszych pięciu hter alfabetu tylko nieliczni uważają za wskazane nau¬ 
czyć się więcej, a co więcej, nauczyć się także czytania tekstów złożonych 
tym alf^etem. 

GDZIE WIĘC JESTEŚ. DUCHU KOMPUTERYZACJI? 

Odpowiedź na pytanie: oczywiście nie opłaca się, bowiem praca ludz¬ 
ka w naszych warunkach jest tańsza niż KOMPUTEROWE WYMYSŁY. 
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Za każdym razem gdy zbliża się termin oddania komentarza (tak w naszym redak¬ 
cyjnym żargome nazywamy teksty drukowane na 3. stronie "Komputera”), zadaję so¬ 
bie pytania: Co, za tych kilka miesięcy, będzie dla naszych czytelników ważne? Na 
czym będzie się koncentrowała uwaga mikrokomputerowego światka? I za każdym 
razem uświadamiam sobie, że to o czym piszę, w chwih pojawienia się numeru w kio¬ 
skach będzie już historią (podobny los spotyka reportaże z wszelkiego rodzaju tar¬ 
gów i wystaw komputerowych, które publikujemy na łamach). To banalna refleksja. 
Towarzyszy ona każdemu dziennikarzowi, a dziennikarzom miesięczników w szcze¬ 
gólności. Mała to pociecha, zwłaszcza że "Komputer” od pewnego czasu ukazuje się 
nieregularnie i ze sporym opóźnieniem. 


Nie tłumaczyliśmy się z opóźnień, bowiem (o ironio!) gdy już się okazało z jakina po¬ 
ślizgiem kolejne numery się ukażą, było za późno, by zdążyć o tym poinformować. 
Teraz, kiedy opóźnienie jest największe wydaje się, iż ten numer powinien dotrzeć do 
rąk Państwa z mimmalnym tylko "poślizgiem”. Mamy taką nadzieję. 

Bez wątpienia naszych czytelników w znikomym stopniu interesują takie czy inne 
powody opóźnień. Nie będziemy ich na łamach rozstrząsać. Wprawdzie jeszcze kilku 
ojców tego "sukcesu” dałoby się bez trudu odszukać,'ale pozostańmy przy zdrowej 
zasadzie, że przed czytelnikami odpowiada tylko redakcja. Staramy się na tyle "pod¬ 
kręcić" tempo prac nad numerami, by jak najszybciej zaległości odrobić. 

Owo "podkręcanie” oznacza w szczególności także i to, że w chwili, gdy piszę te 
słowa, w sprzedaży jest drugi numer "Komputera” a więc niniejszy komentarz ma 
być, z konieczności, pomostem przez cztery numery. Postawione zatem na samym 
początku pytanie w praktyce brzmi: Czy reakcje związane z numerem 2/89 będą ko¬ 
gokolwiek interesowały w lipcu (wówczas zapewne ukaże się numer 6/89)? 

Niezależnie od odpowiedzi na to pytanie jest jedna kwestia, której pominąć milcze¬ 
niem nie możemy. Otóż w numerze 2/89 ukazał się tekst Rolanda Wacławka pt. "Re¬ 
konstrukcja” dotyczący techniki tzw. spolszczania zagranicznego oprogramowania. 
Towarzyszył temu materiałowi niewielki wstęp sygnowany przez redakcję, w którym 
próbowaliśmy wypunktować argumenty za i przeciw tego typu przeróbkom progra¬ 
mów. Oba materiały wywołały dosyć gwahowną reakcję (negatywną) zaprzyjaźnio¬ 
nych z redakcją informatyków, co oznacza zapewne podobną reakcję części środo¬ 
wiska ludzi związanych zawodowe z komputerami. Debrze się stale, że rzecz cala wy¬ 
wołuje dyskusje. Już sam ten fakt jest ważnym powodem, by tego typu materiały pu¬ 
blikować, tym bardziej, że dżentelmeni z faktami nie dyskutują, a powstawanie licz¬ 
nych przeróbek jest bezspornym faktem i nie ma go co nie dostrzegać. Zresztą prote¬ 
stujący koledzy sprzeciwiają się nie tyle drukowaniu materiałów na ten temat, co 
przede wszystkim - jak twierdzą - gloryfikowaniu, czynieniu cnoty z przerabiania 


oprogramowania. 

Nie przesądzajmy sprawy - zdania w redakcji są podzielone. Osobiście, będąc 
przeciwny naruszaniu cudzych praw własności, więcej szacunku żywię dla ludzi dzia¬ 
łających z otwartą przyłbicą, nizli dla takich, którzy starają się działać cichcem. 

Problem, wbrew temu co sądzą purysci (im jest łatwiej bo SŁUSZNOĆ jest pq ich 
stronie), nie poddaje się jednoznacznej klasyfikacji. 

Piszę o tej sprawie bowiem polemika z tezami tekstu "Rekonstrukcja" jest w reda¬ 
kcji dopiero zapowiadana, co oznacza, że ukaże się w numerze 7 89 albo nawet 8/89. 
Taka to już jest "dyskusja" w miesięczniku. Szczęśliwie natomiast się zlozylo, iż w bie¬ 
żącym numerze publikujemy stanowisko Polskiego Towarzystwa Informatycznego w 
sprawie praw autorskich w dziedzinie oprogramowania. Jest to stanowisko jak najba¬ 
rdziej ortodoksyjne. 

Czy żądania środowiska informatyków w tym zakresie zostaną zrealizowane? Czy 
praktyka prawna w naszym kraju będzie na tyle rygorystyczna, by wyeliminować nie 
tylko nachalną grabież cudzych praw, ale także subtelniejsze formy ich naruszania w 
rodzaju spolszczania programów? Osobiście wątpię przypuszczam, ze będziemy 
mieli do czynienia z procesem ewolucyjnym, stopniowo rugującym wątpliwe praw¬ 
nie 1 moralnie praktyki. Jestem, nota bene, zdania, iż wła.śnie taki model*jest dla bran¬ 
ży jedynym realnym i zarazem chyba korzystnym. 
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Na 10 dni przed drukiem 


VOTUM SEPARATUM 

Z mieSięczniKiem "Komputer" współpracuję od chwili jego 
powstania. Nie będąc etatowym praCGwnikiGm star^rn się 
brać udział w zebraniach kolegium redakcyjnego i w miarę 
możliwości współuczestniczyć w kształtowniu charakteru 
pisma. Moje nazwisko stale pojawia się w stopce redakcyj¬ 
nej a i często czytelnicy mogą je znaleźć pod drukowanymi 
artykułami. Ponieważ czuję się związany z redakcją i wielu 
czytelników uważa mnie za jej członka, zmuszony jestem 
zgłosić votum separatum. 

W lutowym numerze "Komputera" z tego roku ukazał się 
artykuł Rolanda Wacławka pod tytułem “Rekonstrukcja”. 
Został on poprzedzony krótkim tekstem wprowadzającym 
podpisanym; Redakcja. Oświadczam, że nie mam z tym 
tekstem ani z poprzedzającą go pseudo-dyskusją nic 
wspólnego. Podpisanie jej imieniem całej redakcji uważam 
za świadome nadużycie autora. 

Temat praw autorskich do oprogramowania kompu¬ 
terowego jest w naszym kraju ciągle jeszcze bardzo kontro¬ 
wersyjny, co niejednokrotnie ujawniło się w różnych dys¬ 
kusjach redakcyjnych. Działalność lansowaną przez 
Rolanda Wacławka (spolszczanie programów bez wiedzy i 
zgody autorów) zawsze uważałem za gangsterskie wyko¬ 
rzystywanie luk w polskim prawodawstwie. 

Jedyne, w czym zgodzam się z Rolandem Wacławkiem, 
to wysokie wymagania jakie stawia on wobec programów 
terowanych polskim odbiorcom i że do ich wytworzenia 
potrzebna jest głęboka i rzetelna wiedza oraz doświad¬ 
czenie. Z żalem przyjmuję do wiadomości fakt, że tak dobry 
programista i fachowiec, jakim jest autor artykułu “Rekon¬ 
strukcja”. cały swój talent i wysiłek skierował na taką 
właśnie działalność. Lansowanie jej przez redakcję "Kom¬ 
putera" i podnoszenie do rangi nowej sztuki programowania 
uważam za oburzający odwrót od dotychczasowej linii 
pisma. Czym innym jest bowiem dostrzeganie zjawisk 
negatywnych lub jedynie kontrowersyjnych, a czym innym 
ich popieranie poprzez odpowiedni dobór tekstów i ko¬ 
mentarzy redakcyjnych. 

Andrzej Kadlof 

Kwestia, której dotyczy votum separatum Andrzeja jest 
zasadnicza i poświęcona jej zostanie dyskusja redakcyjna 
oraz (w najbliższym numerze) jeden z artykułów. 
Stanowisko redakcji jest od dawna oczywiste i zbieżne ze 
stanowiskiem A. Kadlofa. Opisywana sprawa wzbudziła 
kontrowersje także w redakcji i zapewniam, że publikacja ta 
nie miała na celu popierania zjawisk negatywnych, lub ich 
lansowania jako nowej sztuki programowania. Niefortunnym 
było podpisanie wstępu do materiału w imieniu redakcji bez 
konsultacji z zespołem. Mam nadzieję, że było to ostatnie 
tego typu nieporozumienie. 

Marek Młynarski 


W Pewexie 

W sklepach tych oferowane są jako nowość drukarki 
STAR NX 1000 w cenie 259 $. Obsługę gwarancyjną 
zapewnia PZ Karen. Dla porównania drukarka ta w USA 
kosztuje 170 $. a w firmie ABC Data 450 DM. W Europie 
drukarki te są oznaczone jako LC 10. Oferowane przez 
Pewex drukarki dopasowane są do napięcia i częstotliwości 
prądu w Polsce. 


Kolumnę opracował Marek Młynarski 8.VI.1989. 


Errata po raz drugi 

W mumerze 2/89 na str. 24 i 25 zamieściliśmy program 
Bogusława Wożniaka z Lewina Brzeskiego. Niestety, 
chochlik uai znów ?nać o sobie w sposób uniemożliwiający 

uruchomienie tego programu. 

Na początku programu w deklaracji zmiennej Stareint 

określany jest jej adres 0:88, a nie jak mylnie opublikowano 
0:99. W’ procedurze Wyświetl instrukcja write(wynik...) 
powinna mieć postać: write(wynik:18:5); w procedurze 
WpisCyfry powinny być odpowiednie instrukcje: 
pierwsza wynik:=wynikxl0+ord(odczyt)-48 
/ druga wynik:=wynik+(ord(odczyt)-48)xpozycja; 

Po tych poprawkach program działa bez problemu. Za 
pomyłki serdecznie przepraszamy Autora i Czytelników. 
Program CALC.EXE jest dostępny w formie pliku 
źródłowego jak i skompilowanego w redakcyjnym FIDO. 

mikroPRESS 

Z przyjemnością odnotowujemy pojawienie się na polskim 
rynku pierwszego (chyba) biuletynu dyskowego (roz¬ 
prowadzanego nie w formie druku, lecz w postaci zapisu na 
dyskietkach). Jest nam tym przyjemniej, że zarówno jego 
nazwa jak i znaczna część założeń powstała w kręgu 
redakcji “Komputera". 

Biuletyn, którego pierwszy numer został już rozesłany do 
prenumeratorów, będzie się ukazywał kwartalnie. Składają 
się nań omówienia wybranych artykułów z 5 zachodnich 
czasopism komputerowych oraz fiszki wszystkich opubli¬ 
kowanych w nich tekstów. Towarzyszy temu bibliograficzna 
baza danych. Z informacji, które posiadamy wynika, że pre¬ 
numerata nie jest zamknięta. Precezyjne dane można 
uzyskać w Warszawskim Zakładzie Promocji Ogólnopolskiej 
Fundacji Edukacji Komputerowej (tel. 39 01 63). 

__grei 

POLPAK rozpatruje oferty 

Poczta Polska Telegraf i Telefon rozpatruje oferty sprzę¬ 
towe firm zachodnich dla publicznej sieci teleinformatycznej 
- POLPAK. 1 i 2 czerwca odbyło się seminarium, na którym 
swoje propozycje sprzętowe przedstawiły firmy: AREL 
COMPUTERS and SOFTWARE Ltd, TADIRAN oraz DIGITAL 
EOUIPMENT. Poczta planuje uruchomić Sieć Pakietową w 
naszym kraju w połowie przyszłego roku.__ 

Nasza księgarnia oferuje 

Objęta naszym patronatem księgarnia ELEKTRONIKA w 
Warszawie, Mokotowska 51\53 proponuje kolejne nowości z 
WNT: gawędę Roberta L. Babera "O programowaniu ina¬ 
czej" 480 zł, a dla bardziej zaawansowanych Witolda Lips¬ 
kiego "Kombinatorykę dla programistów”, 600 zł. 

Imprezy 

♦ 1 i 2 czerwca w Miedzeszynie KUMP zorganizował semi¬ 
narium “Komputerowe wspomaganie projektowania - 
możliwości, ograniczenia, problemy wdrożeniowe". Po 
wykładzie wprowadzającym doc. dr inż. Jerzego Wróbla 
uczestnikom spotkania (56 osób) swoje możliwości i 
doświadczenia prezentowały firmy APLIKOM, ICS, LOGO- 
TEC engineering, O.K. i TORUS. 

♦ Dr J. Achimowicz, kierownik sekcji Pomiary i Sterowanie 
KUMP, informuje, że tematem obrad 29.06. w klubie NOT 
przy ul. Mazowieckiej będzie “Przemysłowe zastosowanie 
mikrokomputerów" 
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Powszechnie znane są rodzinne przedsiębiorstwa 
chińskie, jak np. chińskie restauracje, sklepy czy war¬ 
sztaty. Czasy zmieniają się Jednak bardzo szybko i na 
Dalekim Wschodzie owe rodzinne przedsiębiorstwa 
bywają dziś zupełnie inne. Jednym z takich rodzinnych 
interesów Jest singapurska fabryka komputerów, zało¬ 
żona przez Patryka i Beniamina Ngiam, którą poza nimi 
zarządzają także dwaj pozostali bracia Ngiam - Ber¬ 
nard i Alfred. 

Rozmawiamy z twórcami liczącej się na rynku euro¬ 
pejskim i dalekowschodnim wytwórni komputerów - 
Patrykiem i Beniaminem Ngiam o powstaniu i rozwoju 
firmy. 

- Essex leży w Wielkiej Brytanii i ma zdecydowanie brytyjs¬ 
ki klimat, a przecież jesteśmy w ESSEX w środku zimy, za ok¬ 
nem jest 27 stopni C ... 

- Nazwa naszej firmy przypomina nam Uniwersytet w Essex, bo¬ 
wiem jesteśmy absolwentami tej uczelni. Po jej ukończeniu Benia¬ 
min pracował dla Hewlett Packard, a ja u Philipsa tu w Singapurze. 
Na początku lat osiemdziesiątych postanowiłem zamienić karierę 
inżyniera naukowca na karierę przedsiębiorcy. Postanowiłem 
utworzyć przedsiębiorstwo Essex, produkujące początkowo płytki 
drukowane, bez wyposażenia, do drukarek. Pół roku później dołą- 
'"zył do mnie Beniamin i zaczęliśmy rozwijać spółkę. Essex rozpo- 

I czął produkcję płytek z wyposażeniem i j^o jeden z głównych do¬ 
stawców dostarczać je Philipsowi. Produkowaliśmy także (i robimy 
to nadal) kontrolery szybkości do maszyn do szycia dla Singera w 
USA. Opanowaliśmy technologię i mieliśmy doświadczenia jako 
dostawcy. 

Pod koniec 1984 roku uznaliśmy, że nadeszła pora na własny pro¬ 
dukt, opatrzony naszym znakiem firmowym, postanowiliśmy wejść 
na rynek komputerowy. Byliśmy przekonani, że nasz towar będzie 
dobry nie tylko w projekcie, ale firma gwarantowała również wy¬ 
soką jakość wykonania. Aby to osiągnąć musieliśmy połączyć 
wszystkie nasze środki, siłę roboczą i zasoby finansowe. W poło¬ 
wie listopada 1984 roku sprzedaliśmy fabrykę i rozpoczęliśmy re¬ 
organizację, która trwała 6 miesięcy. 

W I kwartale 1985 roku pierwsze komputery na rynek krajowy 
były gotowe. Jednocześnie weszliśmy w spółkę joint-venture z Chi- 
nam' (ChRL), produkując komputery na tamten rynek. Szybko zda¬ 
liśmy sobie sprawę, że rynek światowy jest olbrzymi i stie rośnie, 
aby się na nim utrzymać musimy mieć określone minimum wielko¬ 
ści produkcji. W przeciwnym razie nie bylibyśmy konkurencyjni. 
Rozpatrywaliśmy rynek amerykański i europejski, zdecydowaliś¬ 
my się wybrać ten ostatni. Jak już wiecie, nasza rodzina jest znacz¬ 
nie liczniejsza. W Essex pracuje również Alfred Ngiam, absolwent 
Wydziału Nauk Komputerowych Rothwel Uniwersity w Kanadzie. 
Skorzystaliśmy z okazji sprowadzenia go do naszej firmy, aby 
wzmocnić jej dział inżynieryjno-techniczny. Po 1,5 rocznym kursie 
jest on teraz szefem tego działu. W 1986 roku zaangażowaliśmy in¬ 
nego brata, Berriarda, pracującego uprzednio w Change Manhat¬ 
tan Bank jako specjalista analizy kredytowej. Zatrudniliśmy go jako 
dyrektora ds rozwoju biznesu. Dzięki nim, jak też i właściwej strate¬ 
gii marketingowej w latach 1986 i 87 umocniliśmy swoją pozycję w 
Europie, obejmując zasięgiem takie kraje jak RFN, Włochy, Hisz¬ 
pania, Francja, Szwecja a ostatnio także rynek brytyjski. Eksportu- 
jemy komputery także do państw komunistycznych. Współpraca i 


__Nasze rozmowy 

układa się dobrze i chcemy ją rozwijać, sięgnąć dalej na rynek pol¬ 
ski i innych krajów Europy Wschodniej. 

W trakcie tych 7-8 lat firma zmieniła się z prostego dostawcy płyt 
w grupę firm. Mamy spółkę inżynieryjną, marketingową, spółkę na 
Tajwanie, rozwijamy produkcję. Essex jest udziałowcem wielu 
przedsiębiorstw dystrybucyjnych w Singapurze i gdzie indziej. 

- Jak zorganizowana jest Wasza produkcja ? 

- Generalnie nasz system produkcyjny jest w wysokim stopniu 
kapitalistyczny. Jednocześnie uznajemy fakt, że japoński system 
zarządzania jest niezmiernie efektywny i chcielibyśmy go naślado¬ 
wać. Nie jest jednak pewne, czy sprawdzi się on w naszym specy¬ 
ficznym środowisku kulturowym z jego problemami społecznymi, 
poza tym jego osiągnięcie wymaga sporo czasu. Szukamy więc 
kompromisu upodabniając nasz system do japońskiego z zachowa¬ 
niem istoty zarządzania typowego dla Zachodu - ukierunkowanego 
na ludzi i tak, aby pracownicy mieli motywację do pracy jako grupa 
i jako część rodziny firmy. Zasady te ulepszane są w firmach singa¬ 
purskich i dlatego mamy tu tzw. system płacowy sukcesu, popiera¬ 
ny przez rząd. Polega on na tym, że wszyscy pracownicy jako gru¬ 
pa zachęcani są do podejmowania odpowiedzialności za rozwój fir¬ 
my. W tej chwili pracownicy są nastawieni raczej na zachodni sy¬ 
stem pracy, ale będąc w Azji z jej specyficzną kulturą zachowujemy 
się inaczej niż typowi europejczycy. Wynika to z innego wychowa¬ 
nia, wykształcenia, itp., chociaż jeszcze nie osiągnęliśmy całkowi¬ 
cie systemu japońskiego. 



- Właśnie! W jakim społeczeństwie działacie? 

- Jest to jedyne w swoim rodzaju społeczeństwo wielorasowe. 
Żyjemy i wychowujemy się w takim otoczeniu, mamy więc łatwość 
komunikowania i porozumiewania się. Tak więc, pomimo iż kolory 
skóry nas różnią, mamy ze sobą wiele wspólnego z racji pochodze¬ 
nia z Singapuru. Jesteśmy w stanie żyć i pracować razem jako gru¬ 
pa, rasa nie jest i nigdy nie była problemem przy zatrudnieniu. 
Mamy wspólny język, nie tylko angielski, czasem bowiem malaj- 
czycy mówią po chińsku i vice versa. Rząd prowadzi politykę inte¬ 
gracji społeczności, dzielnice mieszkaniowe są wielorasowe, zna¬ 
my wzajemne zwyczaje, różne rasy mogą mieć wspólną religię, np. 
chrześcijaństwo. Nie ma więc konfliktów rasowych, religijnych ani 
komunikacyjnych. 

- Ustanowił Pan dealera w Polsce z myślę o lepszym handlu 
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z Europąt Wschodnią. Jakiego rzędu obrotów spo€lziewa się tam 
Essex? 

- Kraje Europy Wschodniej, według naszej oceny, zaintereso¬ 
wane są produktami wraz z gwarancją serwisową. Nie wystarczy 
tam tylko dostawa sprzętu bez dalszych zobowiązań. Potencjał ryn¬ 
ku jest olbrzymi i trudno mi konkretnie podać, jakich obrotów spo¬ 
dziewamy się. Sądzę, że uda nam się zapewnić dobry serwis i jed¬ 
nocześnie promować jakość naszych wyrobów. Jestem przekona¬ 
ny, że w najbliższym czasie zwiększy się liczba zamówień. Jednak 
na dłuższą metę eksportowanie gotowego wyrobu nie jest właści¬ 
wym rozwiązaniem - takim rozwiązaniem jest udostępnienie tech¬ 
nologii i produkowanie na miejscu. Wówczas dopiero możemy mó¬ 
wić o setkach tysięcy PC z certyfikatami. 

W bieżącym rolm mamy nadzieję sprzedać ok. 5 tys. systemów 
286 i 386. Powtarzam jednak, że na dłuższą metę nie eksport "czar¬ 
nych skrzynek" będzie się liczył, ale eksport technologii, którą bę¬ 
dziemy w stanie przekazać, zapewniając jednocześnie utrzymame 
jakości. 



W naszej strategii kładziemy główny nacisk na stworzenie bar¬ 
dzo dobrej i całościowej sieci marketingowej, z udziałem finanso¬ 
wym firmy Essex. Mamy już dwie spółki w Szwecji, a w nich 40% 
udziałów, inwestorów w Anglii z 30% udziałem, mamy filię w USA 
zajmującą się dalszą ekspansją firmy, tym razem na rynku amery¬ 
kańskim. Filia ta ma siedzibę na zachodnim wybrzeżu USA, utwo¬ 
rzyliśmy ją wyciągu 3 miesięcy, aby skuteczniej wejść na ten najbo¬ 
gatszy w USA rynek. 

- Jakie obroty miał Essex w ubiegłym roku i jaki jest stosu¬ 
nek inżynierów do robotników? 

- W 1988 roku, na samych komputerach, mieliśmy obrót ok. 
35 min dolarów USA. Zatrudniamy 8 inżynierów - naukowców oraz 
3 przy produkcji i 8 techników serwisu. W sumie mamy 80 pracow¬ 
ników, w tym administracją zajmuje się 15 do 20 osób. 

- Jakie sę zarobki w firmie Essex? 

- Zarobki pracowników produkcyjnych w naszej firmie nie są 
najwyższe, ale uchodzą za przeciętne w Singapurze - ok. 650 sin- 
gów miesięcznie, tzn. ok. 325 dolarów USA dla robotnika. Pracują 
oni 44 godziny tygodniowo, płacimy dniówki za 5 dni pracy w tygo¬ 
dniu, praca trwa od 8 do 17.30 z godżinną przerwą na lunch. Do tego 


dochodzi premia miesięczna, premia roczna i inne uznamowe, pła¬ 
tne są też zwolnienia lekarskie. Pierwszego kwietnia przeprowa¬ 
dzamy tzw. przegląd roczny, bierzemy wówczas pod uwagę po¬ 
ziom inflacji, wydajność pracy i ogólny stan przedsiębiorstwa. Są to 
kryteria określające nową siatkę płac dla administracji, handlow¬ 
ców, inżynierów. Przegląd zarobków ma więc charakter roczny. 
Nie znaczy to, że wszyscy na pewno dostaną wyrównanie, ale przy¬ 
najmniej wiedzą "na czym stoją", a poza tym w ten sposób nasze za¬ 
robki są konkurencyjne wobec innych firm singapurskich. 

W fabryce w Singapurze zatrudniamy 145 osób, w całej grupie 
naszych firm ok. 340 do 400 pracowników. Naszą najważniejszą 
kadrą jest 8 inżynierów - naukowców, starannie wyselekcjonowa¬ 
nych i przeszkolonych. Ich kryterium to twórcza innowacyjność 
umysłu, bardzo dobre podstawy do dalszej pracy naukowej. Taki 
świeżo zatrudniony inżynier zarabia ok. 1000 dolarów USA miesię¬ 
cznie, po 3 - 5 latach pracy zarobki jego się podwajają. 

- Opracowuję oni własne karty Essex. Jak długo to trwa np. 
w przypadku karty EGA i czy robicie to samodziebue? 

- Dla EGA cykl technologiczny to 2-3 miesiące przed wprowa¬ 
dzeniem do produkcji. Dla płyt głównych okres ten jest dłuższy, 4-5 
miesięcy w zależności od stopnia skomplikowania, czasem sięga i 
8 miesięcy. Nasi inżynierowie współpracują bardzo ściśle z głów¬ 
nymi dostawcami półprzewodników, przed ukazaniem się na ryn¬ 
ku nowego "chipa" mamy wstępną informację technologiczną, co 
umożliwia szybkie zastosowanie nowego układu i gdy tylko tamten 
produkt jest gotowy, my-też jesteśmy gotowi. Dostawcy pomagają 
nam, gdy to tylko jest potrzebne, np. przy problemach z kombaty- 
bilnością. Zdarza się to rzadko, poza tym nasi iżynierowie są całko¬ 
wicie samodzielni. 

- W jakim wieku sę pracownicy ? 

- Są to ludzie młodzi, ale nie wolno nam zatrudniać osób w wieku 
poniżej 16 lat. 

- A przewodnie hasło firmy na dziś? 

- Można je określić skrótem R.U.B. (responsibility - urgency - 
belonging) - odpowiedzialność, pilność, przynależność. Wierzy¬ 
my, że biznes to nie tylko towary, ale i ludzie. Odpowiedzialność 
jest tym, czego nie można uniknąć. Zawsze jest się odpowiedzial¬ 
nym wobec innych ludzi, firmy, siebie. Czy pracujesz tutaj, czy 
gdzie indziej, czy nie pracujesz - zawsze jesteś sobą na zewnątrz, w 
społeczeństwie. Ważne jest poczucie pilności, przyspieszenia w 
produkcji wysokorozwiniętej technologii, gdyż nie można "zasy¬ 
piać", wszystko należy traktować jako pilne, tak aby rozwiązać 
wszystkie problemy o wiele szybciej. Poczucie przynależności 
sprawia, że pracujemy jako zespól i nie staramy się być "indywidu¬ 
alnymi bohaterami". To poczucie sprawia, że wyżej cenimy interes 
przedsiębiorstwa niż jednostkowy własny. 

Jeśli chodzi o dostawców i klientów najważniejsze jest partners¬ 
two, wzajemność. Ono pozwala na wytworzenie towaru, który nie 
zawiedzie. Ufamy naszym dostawcom, że są w stame dobrze wyko¬ 
nać polecone zadanie. 

- Kilka danych osobistych... 

- Nasi przodkowie byli Chińczykami, tak więc myślę, że jesteś¬ 
my Chińczykami czystej krwi. Mam 34 lata, Beniamin 32, Bernard 
28, Alfred 25. Beniamin, ja i Bernard jesteśmy żonaci, Alfred jest za¬ 
ręczony, ślub odbędzie się najprawdopodobniej w tym roku. Ja 
mam czteroletniego syna i trzynastomiesięczną córkę, Beniamin 
ma już szesnastomiesięczną córkę, drugie dziecko urodzi się za 
miesiąc. Bernard jest rok po ślubie, jak dotąd bez dzieci. Jesteśmy 
średnio zamożną rodziną, no może nieco więcej. 

- Czy komputer jest dobry dla dzieci? Czy jest potrzebny w 

domu? 

- Komputer powinien być narzędziem pracy w szkole, ale nie 
sposobem dostania się do szkoły, np.obecnie większość studen¬ 
tów ma kłopoty z wykonywaniem działań matematycznych bez kal¬ 
kulatora. Korzystne jest docenianie roli komputera, ale nie nadmie¬ 
rne poleganie na nim. Nauka programowania jest dla dzieci zbyt 
trudna, wystarczy ogólne otrzaskanie. Zapozname się z kompute¬ 
rem i praca na nim nie zaspokaja jednak wszystkich wymogów 
edukacyjnych. 

- Dziękujemy bardzo. 
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Stolica Łotwy nie zaznała w tym 
roku prawdziwej zimy. Śniegu było 
niewiele, głównie w grudniu. Być 
może roztopiła go gorąca atmosfera 
stosunków rosyjsko-łotewskich, 
może przyczyniły się do tego tempe¬ 
ratury panujące w obleganych przez 
nastolatków komputerowych koope¬ 
ratywach, czyli spółdzielniach. Kiedy 
indziej poszliby na lodowisko czy z 
sankami lub nartami wyjechali za mia¬ 
sto. Tej zimy, czy raczej jesieni, boć 
przecież zimy w zasadzie nie było, 
zdecydowanie woleli spędzić wolny 
od nauki czas przy joysticku. 

Komputerowych spółdzielni jest w 
Rydze kilkanaście. Zdecydowana 
większość bazuje na przywiezionych 
z polskich PEWEX-ów "małych” Ata- 
ri, rodzimych kolorowych telewizo¬ 
rach, które czas jakiś temu zniknęły z 
radzieckiego rynku, oraz joystickach 
różnej maści, ze wskazaniem na pols¬ 
kie, produkowane w Łodzi przez fir¬ 
mę MATT. 

Nie, nie zajmują się sprzedażą tego 
sprzętu, aczkolwiek znajomi z Mosk¬ 
wy donieśli mi ostatnio o takich właś¬ 
nie zamiarach jednej ze spółdzielni 
moskiewskich. W przeciwieństwie 
do polskich spółek komputerowych, 
w ZSRR kooperatywy zastąpiły auto¬ 
maty do gry, powszechnie spotykane 
w naszym kraju w kawiarniach, re¬ 
stauracjach, dworcach kolejowych. 
Tam robi się pieniądze nie na pośred¬ 
nictwie, a na umożliwieniu młodzieży 
dostępu do sprzętu komputerowego. 
Z reguły, aczkolwiek bywają chlubne 
wyjątki, dostępu ograniczającego się 
wyłącznie do gier. A tych, jak wiado¬ 
mo, w przypadku małego Atari nie 
brakuje. ♦ 

Jeden z takich "KOMPUTERO¬ 
WYCH SALONÓW” - jak z reguły 
głosi napis nad wejściem, mieści się 
w samym centrum Rygi, przy ul. Leni¬ 
na. 

Zderzenie formy (napisu) z treścią 
(wnętrzem) może przyprawić o za¬ 
wrót głowy. Wzdłuż ściany ustawiono 
cztery metalowe stoły, na nich cztery 
kolorowe telewizory, przed każdym 
komputerek starannie owinięty w wo¬ 
rek foliowy (by uniemożliwić dostęp 
do klawiatury) z wyprowadzonym na 
zewnątrz joystickiem. Dostęp do dre¬ 
wnianego stołka przed telewizorem 
ogranicza barierka, na której opierają 
się cierpliwie oczekujący na swoją 
kolejkę amatorzy komputerowego 
hazardu. Na ścianie plakat reklamo¬ 
wy jakiejś gry i odręcznie wypisane 


kartki z nazwiskami rekordzistów. 
Możliwość zapisania się na takiej kar¬ 
tce - to nie lada honor. Obraz zamyka 
znudzony nadzorca, który przycupnął 
ze stacją dysków (a jakże, też zawie- 
niętą w foliowy worek) na krańcu sto¬ 
łów. Do niego należy się zwrócić z 
prośbą o załadowanie z dyskietki do 


żenią czasu gry w zamian za osiągnię¬ 
te wyniki. 

Jurij Zajczonok, który jest jednym z 
trzech członków tej komputerowej 
spółdzielni i współwłaścicielem zgro¬ 
madzonego tu majątku (cena małego 
Atari sięga na ryskim czarnym rynku 
8 tys. rubli, przy 200 rublach przecięt¬ 
nej płacy miesięcznej), z rozrzewnie¬ 
niem wspomina czasy sprzed roku, 
gdy przed jego salonem ustawiały się 
kolejki ogarniętych komputerową 
gorączką obywateli. Przychodzili i 
dorośli, i dzieci. Wtedy należało do 
dobrego tonu pochwalić się w towa¬ 
rzystwie ilością punktów zgromadzo¬ 
nych w walce na pięści z przeciwni¬ 
kiem z kolorowego ekranu. Ba, wtedy 
zdarzali się nawet klienci, rozwiązują¬ 
cy na jego sprzęcie zadania matema¬ 
tyczne, sięgający po Atari zamiast po 
kalkulator. 

To jednak stare dzieje. Dziś i entuz¬ 
jazm nie ten, i poważnych klientów, 
mimo zamieszczanych regularnie w 
miejscowej prasie ogłoszeń, zabra¬ 
kło. Dzieciaki, owszem, dopisują, ale 
to nie ta klientela, którą człowiek 
mógłby się pochwalić w nadziei na 
otrzymanie dyplomu za upowszech¬ 
nianie komputeryzacji. Skomercjali¬ 
zował się cały ten komputerowy inte¬ 
res, ot co. Każdy walczy o utrzymanie 
dochodów. 



"twojego” komputerka ulubionego 
programu, on podpowiada jak grać, 
by wygrać, on jest zarazem kasjerem 
i rozjemcą w konfliktowych sytuac¬ 
jach, gdy rozgrzany walką na miecze 
sąsiad trąci niechcący iimego malu¬ 
cha, uniemożliwiając strącenie kolej¬ 
nego samolotu przeciwnika. 

Wstęp do "salonu” jest bezpłatny. 
Można więc godzinami śledzić za 
sposobem rozgrywania poszczegól¬ 
nych batalii, uczyć się metod walki, 
zapamiętywać zaułki labiryntu, by w 
chwili, gdy nadejdzie Twoja kolej, 
przystąpić do gry z zapasem do¬ 
świadczenia. Jest ono ważne, gdyż 
czas dostępu do komputerka, czy ra¬ 
czej joysticka, limituje opłata uiszcza¬ 
na przed zabawą. Cennik jest, w zasa¬ 
dzie, w całej Rydze jednakowy: 7 ko¬ 
piejek za minutę gry, bez żadnych ta¬ 
ryf ulgowych czy możliwości przedłu- 


A jest o co walczyć. Po opłaceniu 
wynajmu lokalu i podatków trzem 
spółdzielcom z ul. Lenina zostaje jesz¬ 
cze do podziału 1300 rubli. Policzmy: 
cena małego Atari w PEWEX-ie wy¬ 
nosi 85 doi. Stacja dysków jest do ku¬ 
pienia za 175 doi. W sumie komplet 4 
Atari z jedną stacją dysków kosztuje 
515 doi. Przy marcowym kursie bo¬ 
nów w banku - ok. 3000 za bona, czyni 
to kwotę 1.545.000 zł. Wyjeżdżając do 
Polski obywatel ZSRR wymienia ruble 
na złotówki po kursie 160 zł. za rubla, 
a więc za komplet zapłacić musi 9656 
rubli. Przy tak niekorzystnym przeli¬ 
czniku lepiej zaopatrywać się w dola¬ 
ry na własnym czarnym rynku płacąc 
za nie ok. 8-9 rubli w republikach za¬ 
chodnich, lub 6-7 w głębi kraju. Przy 
dobrych znajomościach 515 dolarów 
można więc kupić już za 3090 rubli. 
Zakupiony sprzęt zamortyzuje się już 


po trzech miesiącach. Telewizorów 
kupować nie trzeba. W Rydze jeszcze 
do niedawna można było je wynająć. 

Największą groźbę dla Jurija Zaj- 
czonka i innych spółdzielców z bran¬ 
ży komputerowo-rozrywkowej oka¬ 
zały się pierwsze automaty do gier, 
które zdążyły już dotrzeć do Rygi z 
RFN. Tak przynajmniej twierdzą sami 
spółdzielcy. "Za 15 kopiejek przy od¬ 
robinie wprawy grać można prakty¬ 
cznie w nieskończoność. A tu - mak¬ 
simum godzina, za którą trzeba zapła¬ 
cić 4 ruble 20 kopiejek” - podpowia¬ 
da Jurij Zajczonok. 

Pobieżne nawet obserwacje prze¬ 
czą jednak tym obawom. W hallu ho¬ 
telu "Turist", w którym się zatrzyma¬ 
łem, ustawiono dwa takie automaty. 
Ruch przy nich żaden. Być może fatal¬ 
na jakość obrazu zniechęca do hazar¬ 
du. Za to hotelowy salon komputero¬ 
wy bez względu na porę dnia cieszy 
się dużym wzięciem. Kierownictwo 
hotelu poważnie myśli o jego rozbu¬ 
dowie. "Na razie - informuje mnie za¬ 
stępca dyrektora hotelu Jewgienij Ra- 
wliw, postawiliśmy do dyspozycji go¬ 
ści hotelowych cztery Atari i jeden 
nasz rodzimy komputer BK. Interes 
jest na tyle dobry, że ilość sprzętu 
chcemy zwiększyć dwukrotnie”. 

W cenniku hotelowego salonu znaj¬ 
duję dodtakową pozycję - minuta gry 
na rodzimym komputerze BK. Widać 
nie cieszy się on zbytnią popularnoś¬ 
cią, skoro za minutę gry płacić trzeba 
jedynie 5 kopiejek. Swoją drogą cie¬ 
kawe: a gdyby tak w zbliżony do BK 
pod względem możliwości graficz¬ 
nych komputer Meritum I zaopatrzyć 
salon gier na Dworcu Centralnym w 
Warszawie, ile też kosztowałby do¬ 
stęp doń. I kto komu musiałby płacić? 

Mimo niewielkiej popularności 
komputerków BK dyrekcja hotelu za¬ 
kupiła ich kolejną partię. 10 joystic¬ 
ków MATT przyjechało z Polski, moż¬ 
na więc będzie już wkrótce znacznie 
zwiększyć obroty. Na dodatkowe 
Atari hotelu już nie stać. 

Rozprowadzaniem w repubUce pe- 
wexowskich Atari w sposób zorgani¬ 
zowany zająć się chciała Ryska Izba 
Handu Hurtowego. Poczyniono nawet 
pewne przygotowania, zamawiając 
próbną partię. W ostatniej chwili zre¬ 
zygnowano jednak z transakcji kom¬ 
pensacyjnej, której partnerem miał 
być warszawski Wojewódzki Zwią¬ 
zek Gminnych Spółdzielni "Samopo¬ 
moc Chłopska”. Przyczyna-przepisy 
regulujące sprawę ślęczenia dzieci 
przed ekranami kolorowych telewi¬ 
zorów, które - jak głosi stosowny na¬ 
pis na tylnej części odbiornika - 
mogą być źródłem promieniowania 
twardego. Z odległości kOku metrów 
nie jest to szkodliwe. Co innego, gdy 
"gracze” ślęczą z nosem praktycznie 
w odbiorniku. "Zakup specjalnych 
monitorów kolorowych okazał się 
nieopłacalny” - twierdzi Borys Żak z 
Centrum Obliczeniowego Izby. 

Funkcjonowaniu "KOMPUTERO¬ 
WYCH SALONÓW” przepisy te - 
przynajmniej na razie - zupełnie nie 
przeszkadzają. I mały Sierioża, prze¬ 
cierając załzawione z przemęczenia 
oczy, jutro znów pojawi się w Salonie 
na ul. Lenina, by w walce na miecze 
znów zmierzyć się z barbarzyńcą. A 
kiedy z korpusu przeciwnika, które¬ 
mu Sierioża znów utnie głowę, siknie 
jakże sugestywna mała, czerwona 
fontanna, z piersi malca wyrwie się 
westchnienie ulgi. Mogę grać dalej. 
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Donald Heam, M. Pauline Baker 
”GraRka jnikrokomputerowa”^ z 
angielskiego tłumaczyli Marian 
Łakomy i Jan Zabrodzki, WNT 
1988j wyd. I, 29 700 + 300 egz., 
305 str.j 1100 zlj seria "Mikro¬ 
komputery”. 

Tę książkę chciałbym polecić 
wszystkim Czytelnikom. Nie jest to 
pozycja dla specjalistów, autorzy 
nie wchodzą tak głęboko w proble¬ 
matykę, aby zadowolić naukow¬ 
ców czy praktyków z dziedziny 
grafiki komputerowej, tym niem¬ 
niej omawiają wszystkie istotne za¬ 
gadnienia w sposób przejrzysty i 
zrozumiały, nie stroniąc od proble¬ 
mów trudnych. Krótko mówiąc 
osoby zainteresowane tą tematyką 
powinny koniecznie do tej publika¬ 
cji zajrzeć. 

Autorzy, pracownicy uniwersy¬ 
tetu w Illinois, traktują swoje opra¬ 
cowanie jako wprowadzenie do 
grafiki komputerowej, w związku z 
czym podzielili książkę na pięć 
części. W pierwszej dokonują 
przeglądu sposobów korzystania z 
grafiki komputerowej w projekto¬ 
waniu, przetwarzaniu obrazów, 
handlu, sztuce, nauczaniu, bada¬ 
niach naukowych oraz w domu. Po¬ 
dają ogólne cechy sprzętu i opro¬ 
gramowania systemów graficz¬ 
nych oraz oceniają przydatność ró¬ 
żnych typów komputerów do prac 
graficznych. 

Część druga poświęcona jest 
omówieniu podstaw grafiki oraz 
metod tworzenia obrazów za po¬ 
mocą znaków i pikseh. Tutaj także 
podano różne sposoby rysowania 
obrazów i kreślenia wykresów, łą¬ 
cznie z cieniowaniem i kolorami. 

Średnio zaawansowanym tech¬ 
nikom graficznym poświęcono 
część trzecią. Znalazły się tu takie 
zagadnienia jak transformacje 
obrazów, animacja, metody wyróż¬ 
niania i obcinania elementów obra¬ 
zu. 

Kolejna część dotyczy zaawan¬ 
sowanych technik graficznych, 
głównie obrazów trójwymiaro¬ 
wych, w tym takich zagadnień jak 
usuwania niewidocznych linii, rzu¬ 
tów perspektywicznych i transfor¬ 
macji zarówno wykresów, jak i 
obrazów trójwymiarowych. 

Wreszcie część ostatnia poświę¬ 
cona jest zastosowaniom. Podane 
są tu zarówno przykłady konkret¬ 
nych zastosowań grafiki w różnych 
dziedzinach życia, jak i metody 
skutecznego projektowania pro¬ 
gramów graficznych. 

Dodatkową zaletą książki jest 
kilkadziesiąt zamieszczonych w 


niej programów, liczne rysuidci 
oraz kolorowa wkładka z przykła- 
mi grafiki komputerowej. 

^ ^ 

Krzysztof Sacha, Piotr Misiu- 
rewicZf Tomasz Kręglewski 
"Przewodnik po technice mikro¬ 
komputerowej”, WNT 1988, wyd. 
I, 39 700 + 300 egz., 126 str., 
690 zł. 

Kolejna książeczka, to jedna z 
wielu publikacji typu encyklope¬ 
dycznego. Tym co wyróżnia ją spo¬ 
śród innych, mimo alfabetycznego 
układu haseł, jest szersze omówie¬ 
nie poszczególnych zagadnień. 
Dlatego mamy tu do czynienia ra¬ 
czej ze zbiorem ułożonych alfabe¬ 
tycznie artykułów poświęconych 
podstawowym zagadnieniom 
związanym z budową, zasadami 
działania i oprogramowaniem mi¬ 
krokomputerów. W doborze arty¬ 
kułów głównym kryterium było 
przedstawienie bieżącego stanu 
techniki mikrokomputerowej (bie¬ 
żącego oznacza lato 1987). Skoro¬ 
widze - alfabetyczny i tematyczny 
pozwalają bez trudu odszukać do¬ 
wolne hasło. Książka zawiera też 
słowniczek angielsko-, franusko-, 
niemiecko- i rosyjsko-polski, a 
każde hasło ma swoje odpowiedni¬ 
ki w czterech językach. Należy ją 
polecić wszystkim, zwłaszcza tym 
nie zajmującym się na co dzień in¬ 
formatyką, jako podręczne kom¬ 
pendium. 

S.M.K. 
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Co na to 
Mostostal? 

Astron jest wielkim zachodnio¬ 
europejskim przedsiębiorstwem 
oferującym typowe jednokondyg¬ 
nacyjne budynki przemysłowe jak; 
hale fabryczne, składy, garaże. Ich 
konstrukcja składa się ze spawa¬ 
nych ram stalowych kilku zaledwie 
rodzajów. Firma opracowała sy¬ 
stem Cyprion, w którym lokalni 
przedsiębiorcy budowlani dyspo¬ 
nują komputerami IBM PC łączący¬ 
mi się za pośrednictwem sieci tele¬ 
fonicznej z minikomputerami Pri- 
me w Coventry lub Luksemburgu 
(dla partnerów z kontynentu). 
Przedsiębiorca za pomocą syste¬ 
mu może uzyskać informacje o 
wszelkich oferowanych przez 
Astron budynkach, elementach 
wykończeniowych oraz koszcie 
dostarczenia materiałów. Plany, 
elewacje i aksonometrie budyn¬ 
ków mogą być ukazywane na mo¬ 
nitorze lub wykreślane na ploterze 


Hewlett-Packarda lub zgodnym. 
Na rysunkach mogą być wrysowa¬ 
ne sylwetki ludzi, drzew, samocho¬ 
dów, których wzorce są przecho¬ 
wywane w pamięci komputera. Na 
życzenie dostępne są programy 
obliczające nasłonecznienie po¬ 
mieszczeń, straty ciepła oraz orien¬ 
tacyjny kosztorys budowy. System 
pozwia przedstawić khentowi 
kompletną ofertę w ciągu zaledwie 
godziny, przy czym rozwiązania 
projektowe uwzględniają lokalne 
przepisy budowlane. Od kraju uży¬ 
tkownika zależy również opłata za 
korzystanie z systemu. 

/ADAN/ 

YISILOG 

YISILOG jest pakietem progra¬ 
mowym wizji komputerowej. Opra¬ 
cowany został przez francuską fir¬ 
mę NOESIS, która go rozpowsze¬ 
chnia, we współpracy z krajowym 
Instytutem Badań w Informatyce i 
Automatyce (INRIA) i Wyższą 
Szkołą Górnictwa (Ecole des Mi- 
nes) w Paryżu. Został napisany w 
języku C pod nadzorem systemu 
Unix. Może być więc przeznaczony 
na wszystkie typy komputerów wy¬ 
posażonych w standardowy kom¬ 
pilator C. Obecnie system Yisilog 
oferowany jest do komputerów 
IBM PC lub PC-podobnych, stacji 
roboczych SUN, AppoUo, Micro- 
vax, HP 9000, Buli, Silicongraphics, 
IBM 6150, itp. Współpracuje z kar¬ 
tami Imaging Technology, Matrox, 
System Sud, YMES. Kilka stacji ro¬ 
boczych może zatem pracować ra¬ 
zem z komputerami osobistymi w 
jednej sieci. 

YISILOG jest sprawnym narzę¬ 
dziem cyfrowego przetwarzania 
obrazów i analizy scen dla ośrod¬ 
ków naukowo-badawczych i dla 
opracowania systemów przemy¬ 
słowych. Umożliwia różne zastoso¬ 
wania, w których prowadzi się wy¬ 
krywanie przedmiotów, zliczanie 
cząstek, analizę kształtów i obsza¬ 
rów, itd. Na pr^kład w kontroh ja¬ 
kości, kontroli i detekcji wad, w 
obrazowaniu zjawisk medycznych 
i analizie mikroskopowej, kryst^o- 
grafii, metalografii, petrografii, wi¬ 
dzeniu robotów (rozpoznanie i po¬ 
zycjonowanie przedmiotów, "wizja 
ruchoma”), teledetekcji, nadzoro¬ 
waniu, zastosowanich wojsko¬ 
wych, itd., itd. 

S.M.K. 


WANG W MOSKWIE 

Firma Wang prowadzi w Mosk¬ 
wie negocjacje na temat założenia 
spółki joint-venture, która zajmo¬ 
wałaby się produkcją komputerów 
osobistych oraz oprogramowania 
dla minikomputerów YS-Mini. Dy¬ 
strybucją komputerów "Wang” ob¬ 
jęta byłaby także cała Europa 
Wschodnia. 

Mimo że Ministerstwo Handlu 
USA dopuszcza sprzedaż kompu¬ 
terów do krajów naszego obozu, 
nie zezwala ono jednak jak dotych¬ 
czas na ich wspólną produkcję. 
Stąd też stanowisko ministerstwa 
wobec spodziewanego kontraktu 
jest raczej sceptyczne. Przedstawi¬ 
ciele firmy Wang argumentują, że 
technologia produkcji kompute¬ 
rów osobistych nie jest już obecnie 
nowością, toteż wszelkie ograni¬ 
czenia eksportowe na tym polu są 
przestarzałe i powinny zostać znie¬ 
sione. Dotyczy to naturalnie tylko 
mikrokomputerów osobistych. Na¬ 
tomiast komputery YS-Mini w dal¬ 
szym ciągu dostępne będą wyłącz¬ 
nie za twardą w^utę. 

("Chip” 11/88, s. 423) WNUK 
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nowego 
w Fido? 


W lutym FIDO otrzymało wspar¬ 
cie w osobie naszego nowego ko¬ 
legi Jana Stożka, który przejął gros 
spraw związanych z prowadze¬ 
niem FIDO. 

Redakcja. 

Napisanie czegoś aktualnego o 
FIDO w dniu dzisiejszym 
(04.04.1989) jest bardzo kłopotliwe. 
Po pierwsze ze względu na długi 
cykl wydawniczy (mam nadzieję, 
że numer majowy ukaże się jeszcze 
przed wakacjami), po drugie dlate¬ 
go, że nasz mallbox stoi w przeded¬ 
niu poważnej reorganizacji, która 
w momencie czytania tego tekstu 
będzie prawdopodobnie już fak¬ 
tem dokonanym. Nie bardizo więc 
wiadomo o czym pisać - czy o obe¬ 
cnym wyglądzie naszej sieci (co w 
maju będzie już nieaktualne), czy 
też o projektach i koncepcji nowe¬ 
go mailboKU, co do maja też może 
się zmienić zwłaszcza, że nowy 
program jest nam jeszcze prawie 
nie znany. 

Zacznijmy więc od tego, co na 
pewno nie ulegnie zmianie. Prawie 
na pewno mailbox będzie nadal 
pracował pod bezpośrednim nu¬ 
merem redakccyjnym ( 0 - 22 ) 211 - 
985 w godzinach 16.00 -10.00 w dni 
robocze, w weekendy non stop (od 
16.00 w piątek do 10.00 w ponie¬ 
działek). W TYCH GODZINACH 
BEZPOŚREDNI TELEFON DO RE¬ 
DAKCJI JEST NIECZYNNY!! 
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Na pewno będzie wciąż dostęp¬ 
na spora ilość programów od reda¬ 
kcji, programów rozpowszechnia¬ 
nych jako freeware i Shareware 
(darmowe i płatne dobrowolnie po 
przetestowaniu). Na pewno działać 
będzie skrzynka pocztowa, nadal 
też można będzie otrzymać teksty z 
numerów "Komputera” przed poja¬ 
wieniem się ich w kioskach. Doło¬ 
żymy też starań, aby był publiko¬ 
wany bieżący stan wiedzy o wiru¬ 
sach i koniach trojańskich wystę¬ 
pujących w Polsce wraz z odpo¬ 
wiednimi programami wykrywają¬ 
cymi, zwalczającymi lub zabezpie¬ 
czającymi przed nimi. 


Co więc się zmieni? 

Po pierwsze zmieni się program 
obsługi mailboKu - zamierzamy za¬ 
instalować program Ouick BBS 
znany dzwoniącym do Gdańska 
lub Krakowa. Daje on sporo no- 
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wych możliwości, o które wciąż do¬ 
pytują się użytkownicy (np. możli¬ 
wość drukowania zawartości pli¬ 
ków archiwalnych, nowe, lepsze 
protokoły transmisji danych, i dużo 
innych). Mam też nadzieję, że wre¬ 
szcie zainstalujemy modem umożli¬ 
wiający pracę z prędkością 2400 
Bd. Być może też do maja lub czer¬ 
wca uruchomimy wymianę poczty 
elektronicznej z innymi inaIlboxa- 
mi w kraju oraz za granicą. Pozwoli 
to na utworzenie zalążków ogólno¬ 
polskiej sieci mikrokomputerowej 
oraz znmiejszenie rachunków tele¬ 
fonicznych płaconych przez osoby 
dzwoniące na drugi koniec Polski. 


1 co dalej? 

Reszta w zasadzie zależy od użyt- 
kowmków sieci. Ich liczba wciąż 
rośnie, dzwonią też komputerowcy 
z zagranicy ciekawi tego co się u 
nas dzieje. To użytkownicy decy¬ 
dują w dużej mierze o kształcie sie¬ 
ci. Liczę więc, że zarówno nasi stali 
użytkownicy, jak i nowi, którzy - 
mam nadzieję - się pojawią powita¬ 
ją te zmiany z zadowoleniem. Praw¬ 
dopodobnie w maju będą już znane 
wyniki ankiety, którą przeprowa¬ 
dzamy wśród naszych użytkowni¬ 
ków. Jej wyniki opublikujemy naj¬ 
prawdopodobniej w czerwcu na 
lamach "Komputera” i oczywiście 
w sieci FIDO. 
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Opóźnienia druku naszego mie¬ 
sięcznika sprawiły, że w prezento¬ 
wanym w tej rubryce przeglądzie 
prasowych wiadomości dotyczą¬ 
cych komputeryzacji powstały 
spore zaległości. Dla historii odno¬ 
tujemy jednak przynajnmiej nie¬ 
które fakty z pierwszych miesięcy 
1989 roku: 

Komputer dyscyplinuje 
klienta 

W Opocznie, w sklepie fabrycz¬ 
nym Zakładów Płytek Ceramicz¬ 
nych, wymyślono nowe zastosowa¬ 
nie dla komputera: ZASTĘPUJE 
SPOŁECZNY KOMITET KOLEJKO¬ 
WY. Komputery na świecie mają 
sto tysięcy zastosowań, ale to z 
Opoczna jest nowe i oryginalne 
polskie i - jak słyszeliśmy - na 
specjalistach amerykańskich, za¬ 
chodnioeuropejskich i japońskich 
wywarło ono duże wrażenie. Oto 
bowiem komputer nie tylko wie 
dokładnie kto za kim DZIŚ stoi w 
ogonku po płytki ścienne i podło¬ 
gowe, ale jeszcze pilnuje, żeby nikt 
nie pchał się do sklepu częściej niż 
RAZ NA CZTERY LATA. KUent, 
który chciałby wyłudzić ponowny 
zakup wcześniej niż w 1993 roku, 
albo też przekroczyć limit kupna 
(40 m. kw. płytek na ścianę, 10 m. 
kw. na podłogę) pod pretekstem, 
na przykład, posiadania lokalu o 
większej powierzchni, zostaje naty¬ 
chmiast zdemaskowany dzięki od¬ 
powiednio pojemnej pamięci kom¬ 
puterowej. 

Komputer usprawnia też sam 
proces sprzedaży, eliminując głu¬ 
pie zachcianki klientów usiłują¬ 
cych przebierać w deseniach i ko¬ 
lorach płytek. Wyznacza każdemu 
miesiąc i dzień odbioru zakupu i 
należy brać to, co w tym dniu 
"schodzi z produkcji". Dowiedzie¬ 
liśmy się o tym z łódzkiego "Ex- 
pressu Ilustrowanego", gdzie jed¬ 
nak jakiś malkontent narzeka, iż 
”komputer uzdrowił może kolejkę, 
ale brak mu rozumu, by uleczyć ry¬ 
nek". 

Uroczyste otwarcie nadzorowa¬ 
nej przez komputer kolejki pod 
sklepem fabrycznym w Opocznie 
nastąpiło 2 stycznia bieżącego 
roku. Niestety, już 6 stycznia kom¬ 
puter był zmuszony przetrwać zapi¬ 
sy kolejkowiczów, ponieważ cały 
limit produkcji na rok 1989 został 
wyczerpany. 


Gra na pieniądze 

Na przedwiośniu nadeszła z Ło¬ 
dzi wiadomość, że "już wkrótce w 


salonie gier komputerowych "Ma- 
xim" zostarue zainstalowana ma 
szyna zwana komputerowym po¬ 
kerem. Jest ona obecnie dokładnie 
testowana, sprawdza się niezawo¬ 
dność systemu komputerowego 
dokonującego wypłat. Główna wy¬ 
grana na tej maszynie wynosi mi¬ 
lion złotych." 

Szef salonu oświadczył prasie: 
"Już wcześniej wprowa^iliśmy na 
próbę "elektronicznego pokerzy- 
stę", który może maksymahue pła¬ 
cić 600 tys. złotych. Ponieważ cie¬ 
szy się on dużym powodzeniem, 
zdecydowaliśmy się zainstalować 
maszynę z jeszcze większą wygra¬ 
ną do miliona złotych." 

"Prowadzone sa rozmowy w 
sprawie sprowadzenia do Łodzi 
dalszych maszyn"- dodał szef, ma¬ 
jąc na myśli postępującą inflację. 

„Bajki o zatkanym rynku” 

Przedstawiciel firmy "Star" w 
Polsce (który w rozrąowie z "Ży¬ 
ciem Warszawy" nazywa się Chri- 
stophe Musiał, a w rozmowie z "Ku¬ 
rierem Polskim” już swojsko - 
Krzysztof Musiał) powiedział 
dziennikarzom: 

"W Polsce sprzedajemy więcej 
drukarek niż we wszystkich kra¬ 
jach socjalistycznych razem wzię¬ 
tych". 

"Bajki o zatkanym rynku słyszę 
od półtora roku i śmieję się z nich, 
bo robimy tu coraz lepsze intere¬ 
sy." 

"Sądzę, że polski rynek mógłby 
wchłaniać rocznie nawet 100 tys. 
drukarek (w ub. roku "Star" sprze¬ 
dał ich tu 12 tysięcy). W Hiszpanii- 
nieco podobnej pod względem 
liczby ludności - sprzedaje się 100- 
150 tys." 

"Oceniam, że środki finansowe 
na zakup takiego sprzętu w Polsce 
są, trzeba tylko dostać się do nich 
odpowiednimi argumentami." 

czy kupować programy? 

Na ten temat wypowiedział się w 
"Przeglądzie Tygodniowym” (w 
rozmowie z Janem Rurańskim) dy¬ 
rektor firmy ABC Data - Lech Ma- 
tusiak: 

"W Polsce jest pod tym wzglę¬ 
dem jak w buszu. Program to jest 
coś, co można skopiować, ukraść, 
dostać, wykombinować, ale nie 
kupić, jak na całym świecie. 

-(...) Słyszy się u nas często opi¬ 
nie, że chociaż komputerów rewe¬ 
lacyjnych nie produkujemy, to nasi 
programiści są na niezłym pozio¬ 
mie. Co pan o tym sądzi? 

- To jest dosc skomplikowana 


sprawa. Ogólnie jednak muszę po¬ 
wiedzieć, że polscy softwareowcy 
są daleko za światem. Tu rue cho¬ 
dzi bowiem o geniusz jednostek, 
czy nawet dobrze wykształconych 
grupek ludzi. Tu chodzi o poziom 
organizacji pracy. Dobry program, 
o wielu funkcjach, powstaje w wy¬ 
niku wieloletniej pracy setek ludzi. 
Stopień organizacji pracy w Polsce 
jest za ruski, by uzyskiwać efekty 
porównywalne np. z amerykański¬ 
mi. W tej pracy potrzebna jest dys¬ 
cyplina, którą rozumiem jako pod- 
porządkowarue pewnej idei. W 
Polsce za dużo jest indywidualizmu 
w pracy, a komputer to jest głupia 
maszyna, która nie lubi fantazji. 

- Co trzeba zrobić aby polski ry¬ 
nek szerzej otworzyć na świat? 

- Po pierwsze, dołączyć się do 
wszelkich światowych systemów 
zabezpieczeń wartości pracy. 

- Co pan przez to rozumie? 

- Chodzi o ochronę praw au¬ 
torskich w informatyce. 

- Jest to, pana zdaniem, duży 
problem? 

- Najważniejszy. To jest to, co 
blokuje rozwój polskiej kompute- 

iLUi ^GLcva* 

zy i ograniczenia w transferze tech¬ 
nologii. Dlatego żadna poważna fir¬ 
ma softwareówa nie chce nawet 
zaczynać rozmowy na temat Polski. 
Dopóki nie będzie w Polsce możli¬ 
wości wyegzekwowania praw au¬ 
torskich, dotąd nie będzie można 
handlować poważnymi programa¬ 
mi. Niczym nie krępowana swobo¬ 
da kopiowania programów w Pols¬ 
ce odbija się zresztą i na sytuacji 
polskich programistów, których 
praca nie jest należycie doceniana 
i którzy nie są przez to zmuszani do 
maksymalnego wysiłku. 

- Nie wiem, czy nasza radosna 
komputeryzacja nia załamałaby się 
nagłe, gdybyśmy musieh za pro¬ 
gramy płacić w dewizach. 

- Nie sądzę. Po prostu zakupy 
byłyby bardziej umotywowane 
ekonomicznie, a wkład własnej 
pracy większy - i efekty lepsze." 

Chiwriter czy Yigotekst 

O tym samym napisał w "Głosie 
Wybrzeża” Sławomir Bibulski: 

"Na każdym poważniejszym (np. 
typu targi) spotkaruu, ktoś z miru- 
sterstwa napomyka, że piractwem, 
nielegalnym handlem programami 
komputerowymi należy się zająć, 
ale proceder trwa nadal nieograni- 
czenie. Nawet jest popierany. Jed¬ 
no z wysokich, prestiżowych wyró¬ 
żnień za nowoczesne rozwiązania 
w oprogramowaniu jakim jest na¬ 
groda "Mikro-Laur" przyznana zo¬ 
stała w tym roku grupie inżynierów 
z warszawskiego przedsiębiorstwa 
"Wektor". Ich generator aplikacji 
użytkowych systemów przetwarza¬ 
nia danych jest zwykłą nakładką na 
zachodni program "Foxbase”. Jed¬ 
na więc z tych przeróbek, które tak 
nas kompromitują w oczach powa¬ 
żnych kontrahentów zagranicz- 
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nych! A w Polsce oklaski i splendo¬ 
ry, dyplomy uznania podpisane 
przez poważny Klub Użytkowni¬ 
ków Mikrokomputerów Profesjo¬ 
nalnych przy NOT, przez poważne 
Polskie Towarzystwo Informatycz¬ 
ne... Na stoiskach warszawskiego 
”Komputera’89” roiło się od poniża¬ 
jących środowisko komputerowe 
"zapożyczeń”. Ślad gdański rów¬ 
nież był obecny: spółka ”Vigor” 
sprzedawała edytor tekstu ”Vigo- 
tekst”, który przed przywłaszcze¬ 
niem od firmy Hortsmann nosił zna¬ 
ną wśród użytkowników nazwę 
Chiwriter. A pomiatanie swoim 
szyldem, wplatanie go do nazwy 
produktu, którego wypada się 
wstydzić, jest zabiegiem całkowi¬ 
cie egzotycznym!” 

Jak się dostać do ZSRR 

Na łamach "Przyjaźni” o przesz¬ 
kodach, na jakie napotykają pols¬ 
kie firmy, chcące wejść na rynek 
radziecki, mówił dr inż. Krzysztof 
Sztandera, prezes spółki "Ditkom”: 

''Najpoważniejszyin dla nas pro- 

Ul^lŁŁC:ill xiciiucii yrł 

państwach RWPG przepisy zabra¬ 
niające reeksportu różnych towa¬ 
rów. Druga sprawa, to nie nadąża¬ 
nie kursów walut narodowych za 
kursami dewiz oraz inflacja w Pols¬ 
ce i wynikające stąd trudności w 
podpisywaniu długoterminowych 
kontraktów na niezmienionych za¬ 
sadach finansowych. Ponadto 
sprawa serwisu - polskie przedsię¬ 
biorstwa, takie jak nasze, nie mają 
dotychczas możliwości świadcze¬ 
nia tego typu usług ze względu na 
niemożność uzyskania rubli na wy¬ 
jazdy swoich pracowników do 
ZSRR.” 

"Większość tych problemów 
przestanie wkrótce istnieć, m.in. 
przez wprowadzenie w życie pols¬ 
ko-radzieckiego porozumienia o 
płatnościach w walutach narodo¬ 
wych” - skomentowała tę wypo¬ 
wiedź "Przyjaźń”. 

Zmienia się układ sH 

”Od ubiegłego roku bardzo 
zmienił się układ sił wśród pols¬ 
kich producentów sprżlętu kompu¬ 
terowego - napisał w "Głosie Ro¬ 
botniczym” Jerzy Machejek. - Jesz¬ 
cze nie tak dawno najsihuejsze, dy¬ 
sponujące największym potencja¬ 
łem i planami wrocławskie ”Elwro” 
- wypadło z gry. Po prostu fiaskiem 
okazała się produkcja szkolnego 
Juniora, natomiast składany z kore¬ 
ańskich kitów Elwro 801-AT prze¬ 
grywa konkurencję cenową i jako¬ 
ściową. 

Coraz gorzej wiedzie się dwóm 
innym niedawnym potęgom. Spół¬ 
ka "Mikrokomputery” co prawda 
wypuściła kolejny model Mazovii - 
2016 AT, ale komputer ten wygląda 
szpetnie, jest bardzo skromny i nie 
mając żadnych szans na bogatym 
polskim - wysyłany jest na rynek 
radziecki. Z kolei Mera-Błonie na¬ 
dal oferuje tylko mozaikową dru¬ 


karkę 9-igłową w sytuacji, gdy wie¬ 
lu polskich użytkowników sprzętu 
pracuje na 24-igłowych lub lasero¬ 
wych. Zbyt - taki sam jak Mazovii. 

Natomiast nadal rozwija się Dom 
Handlowy Nauki - stosujący elasty¬ 
czne ceny i warunki transakcji, wy¬ 
chodzący z coraz ciekawszą ofertą 
- ostatnio nawet poszerzoną o 
sprzęt oparty na procesorach 386. 
DHN wyrósł na jednego z najwięk¬ 
szych zaopatrzeniowców naszego 
rynku komputerowego. Warto też 
zauważyć dwie inne, bardzo cieka¬ 
we firmy: łódzką Merę-Połtik ofe¬ 
rującą mini-ploter oraz manipulator 
łódkowy, a także piaseczyński 
"Polkolor”, który wraz z RFN-ows- 
kim Schneiderem wytwarza odpo¬ 
wiednik IBM-owskiego PS/2, sy¬ 
stem wieżowy 386 oraz komputery 
ATiKT.” 

Sfinansujcie sobie sami... 

O komputerach dla szkół mówi 
w "Trybunie Robotniczej" Woj¬ 
ciech Jaros: ”Pierwszą*e^chą kom¬ 
putera popularnego (w tym wy¬ 
padku szkolnego) musi być pro¬ 
stota obsługi. Jeśh nie zdołano 
jej osiągnąć, znaczy to, że produ¬ 
cent przerzuca własne niedoucze- 
me na barki użytkOwTiika. Ten zaś, 
zamiast głośno krzyczeć, że został 
nabrany, przytakuje, gdy tłumaczy 
mu się, że nie dorósł do nowoczes¬ 
ności. 

Szkolić trzeba natomiast konie¬ 
cznie tych, którzy podejmują decy¬ 
zje. W ich działaniach zbyt często 
bowiem odczytać można absolutną 
nieświadomość na co i ile pienię¬ 
dzy wydać. Przykładem może być 
dobra rada, by fundusze na progra¬ 
my zbierały w szkołach... komitety 
rodzicielskie. ” 

Rzeczywiście - rada jest znako¬ 
mita. Równie dobrym pomysłem 
byłaby tylko propozycja, żeby ko¬ 
mitet rodzicielski w szkole zajął się 
sprawą napisania i sfinansowania 
podręczników! Skala przedsięw¬ 
zięcia jest mniej więcej jednakowa. 

Pierwszy krok - od zaraz 

W "Gazecie Współczesnej” 
przeczytaliśmy: 

"Przychodzi petent do urzędu. 
Przedstawia sprawę w okienku. 
Siada, pije herbatę, czeka. Pracow¬ 
nik naciska klawisz, na ekranie 
komputera pojawiają się dane. Na 
ich podstawie powstaje decyzja... 

Taką wizję przedstawia pełno¬ 
mocnik wojewody białostockiego 
do spraw informatyki. Zanim do¬ 
czekamy się tej nowoczesności, 
najpierw trzeba w nią zainwesto¬ 
wać. Białostocki urząd wojewódzki 
robi to metodą drobnych kroków. 
Przy wysokich kosztach kompute¬ 
ryzacji inaczej nie można. ” 

Nam najbardziej się w owej wizji 
spodobało, że w Białostockim 
Urzędzie Wojewódzkim będzie się 
petenta częstowało herbatą. W po¬ 
równaniu ze wspomnianymi wyso¬ 
kimi kosztami komputeryzacji ta 
inwestycja wydaje się stosunkowo 
niewiełka i w związku z tym mogła¬ 
by stać się pierwszym z zapowie¬ 
dzianych drobnych krokow. 

J.R. 

m 


Toczący się nieustannie na na¬ 
szych łamach spór o wyższości jed¬ 
nych języków programowania nad 
drugimi czy pewnych komputerów 
nad irmymi nie ustaje. Na szczęś¬ 
cie, tym razem w listach domino¬ 
wała rzeczowa analiza, a nie posta¬ 
wa w stylu "Mój komputer jest naj¬ 
lepszy”. 

Dwa listy, dwa różne poziomy. I 
co najważniejsze, autorzy wcale nie 
przesądzają, który z omawianych 
przez nich języków progiaiuowa- 
nia 1 komputerów jest naj.... Właś¬ 
nie tak należy dyskutować. 

Wyjątkowo publikujemy też listy 
zupełnie nietypowe dla tej rubryki. 

Redakcja 

Droga redakcjo, 

choć wolę pisać programy, niż listy 
(chyba lepiej mi to idzie), to wypo¬ 
wiedź kolegów z AGH (Edukacja 
Informatyczna, nr 2/89) zmusiła 
mnie do sięgnięcia po pióro. Otóż, 
nie zgadzam się ze wszystkimi wy¬ 
suwanymi przez nich tezami. To 
prawda, że do nauki programowa¬ 
nia Pascal jest o niebo lepszy, niż 
inne języki proceduralne. Po to 
przecież został stworzony przez 
profesora Wirtha. Nie mogę się je¬ 
dnak zgodzić, że jest to równie 
świetne narzędzie do pisania pro¬ 
gramów. Przyzna to chyba każdy, 
kto kiedykolwiek napisał coś np. w 
języku C. Argumentem przema¬ 
wiającym przeciwko Pascalowi 
jest fakt, iż jego kompilatory nie są 
najwyższej klasy translatorami ję¬ 
zyków wysokiego poziomu. Spró¬ 
buję przytoczyć kilka przykładów. 

Na początek proponuję rozpa¬ 
trzeć mainframes (używam tego 
słowa specjalnie,'wyobrażając so¬ 
bie mdlejąego redaktora Eidera, 
ukłon w stronę bardzo dobrej ru¬ 
bryki). (Od pewnego czasu, czego 
autor listu nie zauważył, rubrykę 
"Terminator terminologiczny” re¬ 
daguje Stanisław Królak - red.) Z 
własnej praktyki znam wprawdzie 
tylko MC z rodziny Odra, tym nie 
mniej mogę stwierdzić, że Pascal 
1900 jest po prostu do luftu. Proszę 
np. w tym dialekcie skompilować 
wiersz: 

If Maxint> -Maxint then... 

Również efektywność genero¬ 


wanego przez Pascal 1900 kodu 
pozostawia wiele do życzenia. 

Nieco inaczej przedstawia się 
sytuacja w klasie mikrokompute¬ 
rów klasy IBM PC (innych 16-bito- 
wców ze swej programistycznej 
praktyki, niestety, nie znam). 
Wprawdzie Turbo Pascal ver. 4.0 
czy 5.0 jest rewelacyjny, ale od For¬ 
tranu czy C produkcji Microsoftu 
różni się jedynie lepszym nieco, 
moim zdaniem, edytorem tekstu. 
Niestety, porównania z Aztec C czy 
C + + już nie wytrzymuje. 

Przejdźmy do komputerów 8-bi- 
towych. Dla ZX Spectrum rzeczy¬ 
wiście HiSoft Pascal jest najlep¬ 
szym znanym mi kompilatorem ję¬ 
zyka wysokiego poziomu, ale już 
Turbo Pascal ver. 3.0 w wersji do 
szeroko znanych w naszym karju 
komputerów Amstrad naprawdę 
do wygodnych nie należy. Można 
mu np. zarzucić złą obsługę aryt¬ 
metyki rzeczywistej, częste zawie¬ 
szanie się bez widocznego powo¬ 
du, czy "lądowanie” w CP\M po 
przerwaniu programu, co powodu¬ 
je utratę tekstu źródłowego, który 
przez nieuwagę mógł przecież nie 
zostać zapisany na dysku. 

Moi przedmówcy (przedpisa- 
cze?) jako argumentu przeciwko 
Fortranowi użyli faktu, iż u niektó¬ 
rych studentów wywołuje on febrę. 
Jestem studentem III roku matema¬ 
tyki i II roku informatyki na Uniwer¬ 
sytecie Wrocławskim. Stwierdzam 
autorytatywnie, iż febrę wywołuje u 
moich kolegów również całka Le- 
besgue’a. I co z tego? Podzielam 
natomiast pogląd, kolegów z AGH 
o Prologu. Spośród języków dekla¬ 
ratywnych i mnie podoba się on 
najbardziej. 

Programuję (a właściwie próbu¬ 
ję programować) od 7 lat. Od po¬ 
czątku, stosownie do potrzeb i mo¬ 
żliwości, posługuję się wieloma ję¬ 
zykami, m.in. Pascalem, C, Fortra¬ 
nem, Basicem, Prologiem, a nie tyl¬ 
ko jednym, ukochanym, najlep¬ 
szym. I chyba dlatego wydaje mi 
się, że dobrze poznałem ich wady i 
zalety. 

Wasz stały czytelnik 

Tomasz Kuźmierz 
Jelenia Góra 
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Input-output 
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Chciałbym zabrać głos w toczą¬ 
cej się na łamach "Komputera” 
"wojnie” zwolenników różnych 
komputerów. Mam Atari 800 XL, 
stały dostęp do UNIPOLBRITA 
(zgodny ze Spectrum), poznałem 
nieco Commodore C-64. Oto wyni¬ 
kające z pewnego doświadczenia 
uwagi o niektorycłi zaletach i wa¬ 
dach tych maszyn: 

1. Współpraca z magnetofonem: 
Atari - najgorszy z wymienio¬ 
nych komputerów. Szybkość tran¬ 
smisji bardzo niska. Istnieje co pra¬ 
wda, możliwość zamontowania sy¬ 
stemu Turbo (kilka rodzajów), 
dzięki czemu szybkość wczytywa¬ 
nia zaczyna dorównywać commo- 
dorowskiej, ale komputer ten wy¬ 
maga dodatkowo taśmy żelazowej 
dość dobrej jakości. 

Commodore - szybkość tran¬ 
smisji najwyższa. Dodatkowo mo¬ 
żliwość przyspieszenia programo¬ 
wego. 

Spectrum - szybkość transmisji - 
średnia. Magnetofon musi jednak 
zostać dobrze dostrojony. 

2. Dźwięk: 

Atari - 4 niezależne generatory 
dźwięku. Instrukcja SOUND o czte¬ 
rech parametrach. Możliwość two¬ 
rzenia ciekawych efektów dźwię- 
' kcwych 1 syiTiulówarud mowy ludz¬ 
kiej. 

Commodore - także 4 generato¬ 
ry, jednak brak instrukcji ich ob¬ 
sługi (pozostaje POKE ...). Reszta - 
jak w Atari. 

Spectrum - jeden prymitywny 
generator dźwięku sterowany 
dwuparametrową instrukcją BEEP. 
Prosty w obsłudze, jednak efekty 
nieporównywalnie gorsze, niż w 
poprzednich komputerach. 

3. Grafika: 

Atari - 16 trybów graficznych i 
kilka tekstwoych. Najwyższa roz¬ 
dzielczość w trybie 8:320x192 pun¬ 
kty. Możliwości graficzne bardzo 
duże, również dzięki wielu instruk¬ 
cjom obsługi grafiki (COLOR, 
PLOT, DRAWTO, SETCOLOR, LO- 
CATE i in.). 

Commodore - rozdzielczość nie¬ 
co gorsza niż w Atari. Brak instruk¬ 
cji obsługi grafiki z poziomu Basi- 
cu. Tym nienmiej możliwości grafi¬ 
czne bardzo duże. 

Spectrum - najwyższa dostępna 
rozdzielczość - 256x176 punktów. 
Jeden tryb graficzno-tekstowy 
(pseudotekstowy). Wiele instrukcji 
graficznych (PLOT, PAINT, 
DRAW, CIRCLE i in.). 

4. Basic: 

Atari - dość bogaty. Wygodny 
edytor ekranowy. Prosta obsługa 
operacji we/wy itp. 

Commodore - najgorszy spo¬ 
śród analizowanych komputerów. 
Brak instrukcji obsługi dźwięku i 
grafiki bardzo utrudnia programo¬ 
wanie. Mimo wbudowanego edy¬ 
tora ekranowego poprawianie błę¬ 


dów bardzo niewygodne. Równie 
uciążliwe jest sterowanie kurso¬ 
rem. 

Spectrum - Bogactwo instrukcji 
graficznych wsparte dogodną ob¬ 
sługą zapisu, odczytu i innych ope¬ 
racji we\wy. Instrukcja obsługi 
dźwięku - raczej słaba. Wygodna 
obsługa błędów, jednak edytor li¬ 
niowy uciążliwy, podobnie jak spo¬ 
sób wprowadzania rozkazów oraz 
sterowania kursorem. 

Piotr 

(nazwisko do wiadomości 

redakcji) 
Gdynia 

^ ^ ^ 

Droga Redakcjo! 

Pisałem do Redakcji "Bajtka” w 
1987 roku, pisałem do "dawnego” 
MikroKlanu, pisałem do Dyrektora 
Muzeum Techniki w Warszawie 
zawsze o tym samym, to jest jak od 
jednego entuzjasty otrzymać drogą 
uczciwej zamiany "coś” co jest 
niezbędne drugiemu "narwańco- 
wi . 

Panu Dyrektorowi Muzeum Te¬ 
chniki proponowałem 179 autenty¬ 
cznych zdjęć, naklejonych na pas- 
se-partout, z pierwszej wyprawy 
Zeppelinem dookoła świata oraz 
historię sterowców konstruowa- 
‘ nych i budowanych przez grafa 
von Zeppelina w zamian za "Com¬ 
modore Plus 4”. Pan Dyrektor poin¬ 
formował nmie, że niestety przepi¬ 
sy mu na to nie pozwalają. 

Nie będę wyjaśniał dlaczego nie 
interesują mnie giełdy kolekcjone¬ 
rów (czytaj: rewie nmiejszych i 
większych cwaniaków), dzięki Re¬ 
dakcji mam nadzieję nawiązać 
kontakt z solidnym człowiekiem, 
który ma na "zbyciu" (np. przeniósł 
się na maszynę zgodną z IBM PC 
lub "Amigę”) "Meritum II” z magne¬ 
tofonem lub "Commodore Plus 4" z 
"Datasette" za v/spomniany "zaby¬ 
tek” i kilkadziesiąt kopert z okoli¬ 
cznościami kasownikami Deutsche 
Bundespost z tematu awiacja, w 
tym najwięcej "zeppelinianiów” z 
podobizną grafa von Zeppelina i 
jego aerostatów. 

Piszę to wszystko dlatego, gdyż 
będąc na V roku studiów zarządza¬ 
nia nie mam czym obliczać I, II, III i 
IV kwartyla, o eksponendzie i śre¬ 
dniej wynikowej i-tych wyrazów 
nie wspominając. 

Z wyrazami szacunku 
Jan Olejarczyk 

Tomaszów Lubelski 

^ ^ ^ 

Apel 

Szanowna Redakcjo! 

Jestem opiekunem kółka kom¬ 
puterowego działającego od kilku 
miesięcy przy szkole podstawowej 
w Sanatorium Rehabilitacyjnym dla 
Dzieci w Radziszowie. Użytkujemy 
mikrokomputer Meritum 64 Kb z 
monitorem Neptun i magnetofo¬ 
nem. Niestety, z powodu małej po¬ 


pularności tego sprzętu nasza bi¬ 
blioteka programów liczy sobie 
tylko kilkanaście pozycji. Są to pro¬ 
gramy w Basicu - kilka gier i pro¬ 
gramów użytkowych. 

W naszym sanatorium na paro¬ 
miesięcznych turnusach przeby¬ 
wają dzieci niepełnosprawne - po 
wypadkach, z porażeniami, skolio¬ 
zami i innymi schorzeniami układu 
ruchowego. Dla wielu z nich zaję¬ 
cia kółka komputerowego są 
atrakcyjną formą spędzania wolne¬ 
go czasu. Uczymy się wspólnie ob¬ 
sługi mikrokomputera i podstaw 
programowania w języku Basic. 
Oczywiście, największym zaintere¬ 
sowaniem cieszą się gry. 

Chcielibyśmy nasze Meritum 
wykorzystywać o wiele efektyw¬ 
niej - na lekcjach, przy reedeukacji 
itp. Niestety, brakuje nam progra¬ 
mów edukacyjnych. Brakuje nam 
także literatury dotyczącej tego mi¬ 
krokomputera - np. adresów i spo¬ 
sobów wykorzystania zmiennych 
systemowych, możliwości rozsze¬ 
rzenia Basica o dodatkowe instruk¬ 
cje (np. MERCE, DEF FN) czy mo¬ 
żliwości definiowania własnych 
znaków (jeżeli taka istnieje). Gorą¬ 
co prosimy o zamieszczenie na ła¬ 
mach "Komputera" krótkiego ape¬ 
lu z prośbą o pomoc dla nas. Być 
może znajdzie się ktoś; kto ze¬ 
chciałby podzielić się z nami swoi¬ 
mi wiadomościami lub programa¬ 
mi. Serdecznie z góry dziękujemy. 

Z poważaniem 
Adam Rapiński 
Sanatorium Rehabilitacyjne 

dla Dzieci 
32-052 Radziszów 
woj .krakowskie 

^ ^ ^ 

Wirusy na Commodore 64 

Mam 16 lat i jestem właścicielem 
komputera Commodore 128D, na 
którym dość dużo pracuję. Przez 
już prawie trzy lata zebrałem dość 
dużą bibliotekę programów i bar¬ 
dzo niechętnie rozstałbym się z nią. 
Jednak przeczytawszy Wasz nu¬ 
mer listopadowy szczególnie arty¬ 
kuł "Wirusowa gorączka”, oba¬ 
wiam się, że moje cenne informac¬ 
je mogą ulec zniszczeniu. Chciał¬ 
bym zasięgnąć informacji czy są 
też wirusy na C64, C128. Wiem, że 
wirusy atakują komputery wyższej 
klasy (IBM, An^ga, Atari ST), ale czy 
wirusy "zajmują się" też prymitywny¬ 
mi komputerami takimi jak mój. 

Maciej Banaszek 
Warszawa 

Dochodzą do nas coraz to nowe 
wieści o szerzących się wirusach. 
Na szczęście większość z nich nie 
jest specjalnie złośliwa. Atakują 
one przede wszystkim mikrokom¬ 
putery zgodne z IBM PC. O wiru¬ 
sach zagrażających komputerom 
Commodore jeszcze nie słyszeliś¬ 
my. W każdym razie będziemy ba¬ 
rdzo wdzięczni za każdy sygnał w 

tej sprawie. Redakcja 
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Terminator 


terminolo¬ 


giczny [23] 


Jedna z Czytelniczek (nie tylko 
mężczyźni nas czytają) wytknęła 
nam brak konsekwencji w tytuło¬ 
waniu stałej rubryki poświęconej 
niewielkim programom dla kom¬ 
puterów Atari XE/XL. Raz w tytule 
występowało słowo "mikroprogra- 
my”, to znowu "programiki”. Jak to 
jest? - pyta Pani Małgorzata. Czy 
nie można tytułów ujednolicić? Mo¬ 
żna i trzeba droga Pani Małgosiu, 
ale nie zawsze wystarcza mi sjł i 
cierpliwości, by tego dopilnować. 

Zacznijmy od początku. Kiedy 
rozpoczynaliśmy cykl tytuł "Mikro- 
programy dla Atari XE/XL” miał oz¬ 
naczać po prostu krótkie, kilku- 
wierszowe programy przeznaczo¬ 
ne dla popularnych u nas kompu¬ 
terków. Wkrótce okazało się jed¬ 
nak, że niefrasobliwość nie jest naj¬ 
lepszą cechą dziennikarza. Tytuł 
cyklu był niekiedy przyczyną nie¬ 
porozumień i mieszania pojęć. Dla¬ 
czego? Otóż mikroprogram ma w 
informatyce dość ścisłe znaczenie. 
Aby wyjaśnić sens tego pojęcia, 
trzeba by wejść głęboko w archi¬ 
tekturę komputerów. Z grubsza 
biorąc chodzi tu o pewien sposób 
pracy jednostki sterującej kompu¬ 
tera. Słowa sterujące, które opisują 
mikrooperacje wykonywane w ko¬ 
lejnych krokach zapamiętywane są 
w specjalnej pamięci. Sekwencja 
takich mikrorozkazów nazywana 
jest mikroprogramem. 

Programy dla Atari, mimo że 
małe, z mikrorozkazami mają tyle 
wspólnego, co żaba z jeżem. Tytuł 
rubryki zmieniliśmy i... zaczęły się 
schody. Zarówno Tomasz, prowa¬ 
dzący rubrykę, jak i Piotr, makietu¬ 
jący kolejne numery "Komputera", 
okazali się osobnikami bardziej 
odpornymi na wpływy zmieniają¬ 
cego się świata niż dziobak i kol¬ 
czatka. Prośby pozostają bez echa, 
groźby są skuteczne, ale na krótko. 
Gdy mija zagrożenie zamiast pro¬ 
gramików pojawiają się znowu mi- 
kroprogramy. Skutecznym rozwią¬ 
zaniem byłby pewnie czekista z na¬ 
ganem w ręku. Sęk w tym, że na to 
rozwiązanie mnie nie stać. Jeszcze 
nie dorosłem! 
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Ryszard Tadeusiewicz, Andrzej Izworski 

Komputer 
dla medyka [3] 


Zamieszczamy po dłuż¬ 
szej przerwie kolejny arty¬ 
kuł z cykłu "Komputer dla 
medyka". 

Przypominamy, że odcin¬ 
ki 1. i 2. ukazały się w "Kom¬ 
puterze" w numerach 11/88 i 
12/88. Jednocześnie prze¬ 
praszamy Autorów i Czytel¬ 
ników za przerwę w publi¬ 
kacji. Redakcja 


Dwa poprzednie odcinki cyklu 
poświęcone były podstawowej 
analizie statystycznej danych typu 
ilościowego. Dane te opisuję fakty 
dajęce się wyrazić w formie opiso¬ 
wej, niemożliwe natomiast jest dla 
nich wprowadzenie wartości licz¬ 
bowych - chyba że w sposób arbi¬ 
tralny, na zasadzie określonej umo¬ 
wy. Przykładów danych tego typu 
jest w praktyce medycznej dużo. 


Płeć pacjenta, obecność lub brak 
(wraz z ewentualną ocenę nasile¬ 
nia) określonych objawów, opis 
stanu klinicznego, streszczenie wy¬ 
wiadu lekarskiego, dane o pocho¬ 
dzeniu społecznym i zawodov/ym 
chorych - to tylko nieliczne przy¬ 
kłady. Opracowywanie statystycz¬ 
ne danych typu jakościowego musi 
odbywać się na innych zasadach, 
niż opisywane wcześniej oblicza¬ 
nie średnich i odchyleń standardo¬ 
wych dla danych ilościowych. Po¬ 
wodów wzmiankowanej odmien¬ 
ności można byłoby wyliczyć wie¬ 
le, ale wystarczy wspomnieć o dwu 
podstawowych: Nawet jeśli wpro¬ 
wadzi się (co będzie dalej koniecz¬ 
ne) umowny sposób kodowania 
liczbowego wartości zmiennych ja¬ 
kościowych, to jednak na liczbach 
tych nie będzie można w sposób 
sensowny przeprowadzać żad¬ 
nych operacji arytmetycznych. Po¬ 
służmy się przykładem - celowo 
absurdalnym, aby podkreślić 
wagę przytoczonego wyżej stwier¬ 


dzenia. Otóż, umawiając się, że 
płeć kodować będziemy w ten 
sposób, by wartość 1 odpowiadała 
kobiecie, a wartość 2 - mężczyźnie 
możemy bez trudu wprowadzić tę 
ważną informację o pacjencie do 
używanego komputera. Dopusz¬ 
czając jednak do wykonywania na 
tych danych działań arytmetycz¬ 
nych zgadzamy się na to, by kom¬ 
puter utożsamiał każde dwie ko¬ 
biety z jednym mężczyzną! Mało 
tego. Wyliczając określone wyniki 
(na przykład chętnie używane i na¬ 
dużywane średnie) możemy do¬ 
prowadzić do uzyskania rezultatów 
pozbawionych interpretacji. Jak na 
przykład rozumieć wynik, głoszą¬ 
cy, że średnia wartość parametru 
”płeć” wynosi 1,75 ? Tak więc obok 
nonsensowności działań arytmety¬ 
cznych, także trudności w interpre¬ 
tacji wyników, skłaniają do takich 
metod przetwarzania danych jako¬ 
ściowych, które nie muszą bezpoś¬ 
rednio angażować działań arytme¬ 
tycznych na wartościach samych 


12 <OmPUCE^ 
















































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































Komputery i medycyna 


danych. Na szczęście istnieję takie 
metody przetwarzania i mogę być 
one realizowane przez komputer - 
pod warunkiem, że użytkownik 
"uprzedzi” maszynę, że właśnie ma 
do czynienia z danymi typu jakoś¬ 
ciowego. Podany niżej program 
dostarcza takich właśnie możliwo¬ 
ści. 

Wierni Czytelnicy tego cyklu pa- 
miętaję zapewne, iż już pierwszy z 
proponowanych do wpisania pro¬ 
gramów oferował rozróżnienie po¬ 
między danymi ilościowymi i jako¬ 
ściowymi, jednak zadeklarowanie 
wówczas chęci przetwarzania da¬ 
nych jakościowych wywoływało 
mało ciekawy efekt (pojawiał się 
wydruk informujący o braku możh- 
wości przetwarzania takich da¬ 
nych). Teraz program nasz można 
istotnie wzbogacić. Aby to zrobić 
w sposób niezależny od wcześniej¬ 
szych części programu, wystarczy 
po prostu wpisać podany niżej 
wydruk - i program gotowy. Jeżeli 
jednak chcemy (do czego wypada 
wszystkich systematycznych Czy¬ 
telników goręco zachęcić) połę- 
czyć omawiany program z wcześ¬ 
niej wpisanymi częściami uniwer¬ 
salnego systemu, wówczas trzeba 
postępić inaczej, niż podano we 
wcześniejszych odcinkach. Otóż 
trzeba najpierw załadować po¬ 
przednie fragmenty programu (in¬ 
strukcję ENTER ”C: dla kasety lub 
ENTER ”D:SYSTEM w przypadku 
przechowywania programu na dy¬ 
skietkach), a dopiero później moż¬ 
na wpisać podany niżej tekst pro¬ 
gramu. Taka kolejność postępo¬ 
wania jest zalecana z tego powodu, 
że nowy, niżej przytoczony, pro¬ 
gram zawiera instrukcje, które po¬ 
winny zastępić instrukcje zawarte 
we wcześniej napisanej wersji pro¬ 
gramu (właśnie te, które informo¬ 
wały o niemożności przetwarzania 
danych jakościowych). Tak więc 
stali Czytelnicy rubryki powinni 
postępować zgodnie z podanym 
zaleceniem, a uzyskaję nowę 
"przybudówkę” do regularnie two¬ 
rzonego systemu. Natomiast no¬ 
wicjusze, ci którzy nie dysponuję 
wcześniejszymi programami mogę 
wpisać podany niżej program jako 
samodzielnę jednostkę. Dla zape¬ 
wnienia wygody posługiwania się 
takim samodzielnym modułem na¬ 
leży dodatkowo wpisać oddzielnie 
przytoczony fragment programu (o 
numerach linii mniejszych od 100), 
co zapewni ułatwienie dobrze zor¬ 
ganizowanego wprowadzania nie¬ 
odzownych danych i pozwoli na sa¬ 
modzielne (niezależne od systemu) 
używanie podanego programu. 
Dotyczy to tylko tych 


Czytelników, którzy nie korzystali z 
wcześniejszych odcinków cyklu, 
pozostali maję już odpowiednie 
oprogramowanie w pamięci swo¬ 
ich komputerów i mogę poprze¬ 
stać na wpisaniu wyłęcznie głów¬ 
nego segmentu rozważanego pro¬ 
gramu, resztę maję już gotowę od 
dawna. Dodatkowę premię będzie 
dla nich możliwość opuszczenia 
podczas wpisywania wszystkich li¬ 
nii o numerach większych niż 20 
000 za wyjętkiem linii: 

20 017 

20 018 

20 025 

20 512 

20 585 

21 500-21550 

30 100 

Po wpisaniu programu, w wersji 
samodzielnej lub w charakterze 
uzupełnienia wcześniej rozpoczę¬ 
tego systemu, można go wypróbo¬ 
wać, podajęc mu przykładowe 
dane (oczywiście po uprzednim 
uruchomieniu programu komendę 
RUN). Przy okazji zapoznamy się z 
własnościami i możliwościami na¬ 
szego nowego produktu. Otóż, jak 
już stali Czytelnicy pamiętaję z 
wsześniejszych artykułów, dane sę 
ponumerowane i numery te stano¬ 
wię stałe (w całym cyklu obliczeń) 
identyfikatory tych danych. Nume¬ 
ry nadaje użytkowrdk swoim da¬ 
nym w sposób całkowicie dowol¬ 
ny, uważajęc jedynie na to, by nie 
podać dwukrotnie tego samego 
numeru, gdyż wówczas nowe infor¬ 
macje, podane dla danej o wysele¬ 
kcjonowanym numerze, spowodu¬ 
ję skasowanie poprzednich zapi¬ 
sów. Po wyborze danej w progra¬ 
mie, który stanowi kontynuację i 
rozbudowę systemu wcześniejsze¬ 
go, następuje pytanie o rodzaj roz¬ 
ważanej danej - czy jest ona typu 
ilościowego, czy jakościowego. W 
programie pisanym na doraźne po¬ 
trzeby, na podstawie przytoczone¬ 
go niżej tekstu, pytanie takie nie 
występuje, ponieważ jest bez¬ 
przedmiotowe. Oddajęc do dyspo¬ 
zycji użytkownika program prze- 
twarzajęcy wyłęcznie dane jakoś¬ 
ciowe nie możemy w sposób sen¬ 
sowny sugerować możliwości uży¬ 
cia danych odmiennego typu. Ko¬ 
lejny etap wprowadzania informa¬ 
cji wymaga podania hczby rozróż- 
nialnych wartości (poziomów) da¬ 
nej jakościowej. Ponieważ używa¬ 
na w tym przypadku terminologia 
nie jest oczywista sama przez się, 
przeto warto na tym szczególe sku¬ 
pić swoję uwagę nieco dłużej. Otóż, 
dla sensownego przetwarzania da¬ 
nych jakościowych (opisowych, a 
nie numerycznych) w komputerze, 
który najchętniej operuje liczbami, 


należy poszczególnym możhwym 
kategoriom danej jakościowej 
przypisać określone numery. Za¬ 
bieg ten ma charakter wyłęcznie 
porzędkowy i sposób przypisania 
wartości poszczególnym katego¬ 
riom rozważanej danej może być 
całkowicie dowolny, chociaż w 
przypadku, gdy kategorie te ukła 
daję się w logicznę sekwencję (na 
przykład wczesne i późne wyniki 
leczenia, brak lub coraz silniej zaz¬ 
naczone objawy choroby, wielkoś¬ 
ci odczynu serologicznego itp.) ce¬ 
lowe jest zachowanie logicznej ko¬ 
lejności przypisywanych poszcze¬ 
gólnym katagoriom numerów, 
gdyż ułatwi to zarówno wprowa¬ 
dzanie danych, jak i interpretację 
wyników. Dla komputera jest to je¬ 
dnak obojętne - jemu zależy tylko 
na dokładnej i pewnej informacji, 
ile poziomów wyróżniono. I tak - 
przykładowo - dla wielokrotnie 
wyżej cytowanej danej PŁEĆ natu¬ 
ralne jest przyjęcie dwóch pozio¬ 
mów, dla ilości wykrytych w bada¬ 
niu mikrobiologicznym bakterii 
(kodowanych zwyczajowo według 
zasady: [-] brak, [+] obecne, [ + + ] 
liczne, [ + + + ] bardzo liczne) natu¬ 
ralne jest przyjęcie czterech pozio¬ 
mów, zaś dla wielu badań i ozna¬ 
czeń laboratoryjnych korzystne 
jest stosowanie skali trzypoziomo¬ 
wej: 1 = poniżej normy, 2 = w nor¬ 
mie, 3 = powyżej normy. Zresztę 
sposób kodowania i interpretacja 
poziomów danych jakościowych 
jest sprawę indywidualnych upo¬ 
dobań korzystajęcego z komputera 
lekarza. Warto jedynie we włas¬ 
nym, dobrze pojętym interesie, sta¬ 
rać się przyjmować stale takie 
same konwencje zapisu danych, 
gdyż tylko wtedy możliwe jest wy¬ 
robienie przyzwyczajeń, bardzo 
ułatwiajęcych pracę. 

Po określeniu liczby poziomów 
dla wprowadzanej danej program 
pyta o liczbę jej powtórzeń (obser¬ 
wacji). Przypomnijmy - bo nigdy 
dość przypominania spraw o fun¬ 
damentalnym znaczeniu - że 
wszelkie wiarogodne wnioskowa¬ 
nie w naukach przyrodniczych, a 
zwłaszcza w biologii i w medycy¬ 
nie, musi być oparte na sekwen¬ 
cjach obserwacji. Ogólnie - im 
więcej obserwacji rozważanej da¬ 
nej, tym lepiej, gdyż wiarogodniej- 
sze będę wycięgane wnioski. Nale¬ 
ży przy tym jednak zwrócić uwagę 
na następujęcy szczegół: jako od¬ 
dzielne dane traktowane być mogę 
nawet jednorodne pod względem 
treści informacje, w przypadku, 
gdy dotyczę rozłęcznych - z punktu 
widzenia celów badań - grup ob¬ 
serwacji. Przykładowo, jeśli poró- 


nujemy zmiany w zapisie EEG po 
różnych rodzajach urazów ośrod¬ 
kowego układu nerwowego, to nie 
możemy cechy "zmiany zapisu o 
charakterze ogniskowym" trakto¬ 
wać jako pojedynczej danej, gdyż 
wówczas proces obróbki statysty¬ 
cznej "wrzuci do jednego worka” 
wszystkich pacjentów, niezależnie 
od rodzaju przebytego urazu. Trze¬ 
ba natomiast wyróżnić tyle danych, 
ile kategorii urazów zamierzamy 
rozpatrywać i dla każdej z tych ka¬ 
tegorii osobno policzyć i zadekla¬ 
rować liczbę obserwacji. Będę 
więc rozpatrywane dane postaci 
"obecność w zapisie EEG zmian 
ogniskowych u pacjentów z pier¬ 
wotnym uszkodzeniem pnia móz¬ 
gu” i temu podobne - dla innych 
urazów i dla (ewentualnie) innych 
objawów - elektroencefalograficz- 
nych lub klinicznych. Tak więc ry¬ 
gorystyczne wymogi prawidłowo 
prowadzonej analizy statystycznej 
już na poczętku sprawiaję wielu 
użytkownikom naszego programu 
pewnę trudność. Otóż, z reguły po 
potraktowaniu jako oddzielnych 
danych wszystkich wydzielonych 
grup (ze względu na cel badań) ob¬ 
serwacji i badań, okazuje się, że w 
niektórych grupach jest bardzo 
mało obserwacji... Zgodnie z przy¬ 
toczonymi wcześniej ogólnymi 
uwagami oznacza to, że w grupach 
tych wnioskowanie statystyczne 
będzie "słabe”, co szczególnie da 
się zauważyć, kiedy będziemy opi¬ 
sywali programy weryfikujęce 
określone hipotezy badawcze na 
podstawie zgromadzonych da¬ 
nych. Lepiej jednak mieć świado¬ 
mość tego stanu rzeczy od razu, niż 
mieć złudzenia i zabierać się do 
obliczeń komputerowych, majęc 
opisanych kilkunastu chorych, po¬ 
dzielonych w dodatku na kilka 
grup. Te podziały maja zresztę ten¬ 
dencję do podstępnego mnożenia 
się. Oto jak to typowo przebiega: 
Majęc świadomość ograniczonej h- 
czebności posiadanego materiału 
obserwacyjnego lekarz podejmuje 
bezwarunkowo słusznę decyzję, 
aby ograniczyć swoję analizę do 
czterech zaledwie rozróżnianych 
jednostek chorobowych. W zesta¬ 
wieniu z - powiedzmy dla przykła¬ 
du - sześćdziesięcioma zarejestro¬ 
wanymi i opisanymi przez siebie 
przypadkami, wydaje się to założe¬ 
niem bardzo ostrożnym i umiarko¬ 
wanym. Jednak już w czasie analizy 
zaczynaję się niespodzianki. Oka¬ 
zuje się, że oczywiście trzeba po¬ 
dzielić populację według płci, 
gdyż istnieję przesłanki, aby po¬ 
dejrzewać, iż analizowane zjawis- 
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ko inaczej przebiega u kobiet, a 
inaczej u mężczyzn. Dalej, oczywi¬ 
sty i narzucający się jest podział 
według wieku. Wszak choroba bez 
wątpienia inaczej przebiega u dzie¬ 
ci, inaczej u dorosłych i inaczej u 
osób w podeszłym wieku. Wiedząc 
o konieczności oszczędnego po¬ 
działu nasz badacz rezygnuje (z du¬ 
żym żalem, bo widywał takie wyni¬ 
ki w literaturze) z podziału na deka¬ 
dy wieku (od 0 do 10 lat, od 11 do 
20, od 21 do 30 itd.) i "zaciskając 
pasa” wyróżnia tylko trzy kategorie 
wiekowe: dzieci, osoby dorosłe i 
starców. Wreszcie oczywiste staje 
się, że konieczne jest odróżnienie 
przebiegu choroby w przypadku 
pierwszego z nią kontaktu, oraz w 
przypadku zachorowań nawraca¬ 
jących. Takich oczywistości można 
by mnożyć więcej, ale poprzestań¬ 
my na tych, już wymienionych, nie¬ 
wątpliwie podstawowych. I cóż się 
okazuje ? Prosty rachunek pokazu¬ 
je, że naszych 60 przypadków, plon 
wieloletnich badań i benedyktyńs¬ 
kich, systematycznie prowadzonych 
zapisków, podzielić trzeba aż na: 

4*2*3*2 = 48 klas. 

Nawet przy założeniu (optymalnym 
z punktu widzenia interesów bada¬ 
cza, a zwykle nie spełnionym), że 
poszczególne podziały dzieliły po¬ 
pulację na jednakowo liczne części 
- i tak w poszczególnych klasach 
możemy spodziewać się jednej do 
dwu obserwacji... Systemy kompu¬ 
terowej obróbki danych medycz¬ 
nych pozwalają często na swobod¬ 
ne zadawanie kryteriów podziału 
posiadanego zbioru danych i za¬ 
chęcają wręcz do takich podziałów 
łatwością ich realizacji. Użytkow¬ 
nik korzysta z nich i nie może wyjść 
z podziwu, dlaczego w rezultacie 
uzyskuje wiadomość, że powstałe 
podzbiory danych są zbyt mało li¬ 
czne, by mogły być przedmiotem 
jakiejkolwiek analizy. 

W naszym systemie lekarz ko¬ 
rzystający z mikrokomputera ma 
też możliwość opisania swoich da¬ 
nych w postaci dowolnie podzielo¬ 
nych podzbiorów, jednak robiąc to 
"ręcznie” zachowuje świadomość 
tego, co robi, a także orientuje się, 
jak to wpływa na liczebność jego 
pracowicie zgromadzonych da¬ 
nych- Powtórzmy raz jeszcze: lep¬ 
sza przykra świadomość, niż iluzje 
bez pokrycia... 

Drugim punktem, w którym ba¬ 
dacz musi wykazać rozsądną pow 
ściągliwość, jeśli nie chce narazić 
się na kłopoty z niewystarczającą 
liczbą danych, jest liczba pozio 
mów wyróżnionych w opisie "war¬ 
tości” danej typu jakościowego. W 
pogoni za "ideałem’*, jakim dla wie¬ 
lu lekarzy są dane ilościowe, doko 


nuje się przesadnie drobnej kate¬ 
goryzacji danych jakościowych, 
kodując i zapisując stany pośred¬ 
nie, niuanse i półcienie. W wielu 
przypadkach taka działalność 
przynosi bardzo korzystne rezulta¬ 
ty, bywa jednak i tak - wprowadza 
się dla opisu danej jakościowej tak 
dużo poziomów, że po wprowadze¬ 
niu konkretnych wartości dla 
potencjalnie możliwych "wartości” 
rozważanej danej nie wystarcza 
obserwacji. Po prostu takie wartoś¬ 
ci w ogóle nie występują, lub wy¬ 
stępują bardzo rzadko. Jest to bar¬ 
dzo niekorzystna sytuacja, gdyż w 
dalszych obliczeniach wykorzystu¬ 
je się tak zwane "tablice 
kontyngencji” (dokładnie o nich - 
w następnym odcinku), w których 
powstają na skutek przesadnego 
rozdrobnienia danych uciążliwe 
luki. W rezultacie często bywa tak, 
że zbyt szczegółowa "skala” wpro¬ 
wadzona dla wielkości jakościo¬ 
wych prowadzi do pogorszenia 
wyników analizy. Przy deklarowa¬ 
niu hczby poziomów występują¬ 
cych w używanej danej jakościo¬ 
wej trzeba więc przestrzegać zasa¬ 
dy: Jak najmiuej poziomów, tyle je¬ 
dnak, by nie zatarły się istotne ce¬ 
chy badanego zjawiska. Lepiej 
więc wprowadzić dwa poziomy: na 
przykład widoczna poprawa stanu 
zdrowia oraz brak takiej poprawy 
pomimo podejmowanej kuracji, niż 
wprowadzać dziesięciopunktową 
skalę ocen stopnia wyleczenia, 
którą potem bardzo trudno będzie 
konsekwentnie i bezbłędnie wy¬ 
pełniać. Nikt jednak nie twierdzi, 
że w opisie cechy PŁEĆ celowe 
jest zredukowanie powszechnie 
stosowanej dwuelementowej po- 
działki do jednej wspólnej katego¬ 
rii "człowiek”... 

Powróćmy do programu, będą¬ 
cego treścią tego odcinka. Pro- 
grćun ten, po dostarczeniu mu da¬ 
nych, pozwala obliczyć i wydruko¬ 
wać parametry statystyczne, będą¬ 
ce odpowiednikćuni parametrów 
opisywanych w pierwszym odcin¬ 
ku cyklu dla danych ilościowych. A 
więc głównie wyznaczana jest me¬ 
diana - odpowiednik wartości śre¬ 
dniej, będąca także miarą tzw. ten¬ 
dencji centralnej. Dalej, obliczana 
jest i prezentowana na ekranie mi¬ 
krokomputera miara stopnia roz¬ 
rzutu opracowywanej danej, analo¬ 
giczna do odchylenia standardo¬ 
wego, lecz oparta na tak zwanych 
kwantylach. Mając do dyspozycji 
medianę (może ona być tu uważana 
za wartość, która z największym 
prawdopodobieństwem jest repre¬ 
zentantem wszystkich wartości 
przetwarzanej danej) oraz dyspo 
nując miarą ich rozrzutu, możemy 
poczynione obserwacje w sposób 
systematyczny prezentować w ra¬ 
portach zbiorczych łub poddawać 


dalszym analizom. Dla pełnego 
scharakteryzowania analizowanej 
danej program podany niżej okre¬ 
śla jeszcze i prezentuje tak zwany 
histogram, to znaczy informację o 
tym, ile razy rozważana dana przyj¬ 
mowała każdą ze swych wyróżnio¬ 
nych wartości. Na histogramie zau¬ 
ważyć można między innymi, jak 
układa się zbiór wartości danej wo¬ 
kół mediany, można także łatwo 
wyodrębnić tzw. wartość modalną, 
to znaczy taką, która przyjmowana 
była przez daną najczęściej. W re ¬ 
gularnie zachowujących się da¬ 
nych wartość modalna jest identy¬ 
czna z medialną; brak takiej zgod¬ 
ności zmusza do zastanowienia się, 
czy dana została poprawnie zdefi¬ 
niowana. Być może usiłujemy opi¬ 
sać dwa zjawiska na raz? 

Na zakończenie rady dla stałych 
Czytelników (dla nowicjuszy za 
chwilę - w końcu stałym Czytelni¬ 
kom coś się należy za ich wier¬ 
ność). Mając zapisany i wypróbo¬ 
wany program, będący rozszerzo¬ 
ną ( o omówioną część) wersją na¬ 
szego regularnie budowanego sy¬ 
stemu, warto go zapisać w dwu po¬ 
staciach. Po pierwsze trzeba zape¬ 
wnić wygodę używania programu 
w przedstawionej postaci. W tym 
celu używamy dyrektywy SAVE (w 
znanej już wersji dla taśmy lub dla 
dysku). Warto także zapewnić za¬ 
pamiętanie źródłowej wersji pro¬ 
gramu by móc ją rozbudowywać 
po zapoznaniu się z kolejnymi odci¬ 
nkami. Użyjemy tu dyrektywy LIST. 
Natomiast posiadacze wyłącznie 
omówionego w tym odcinku pro¬ 
gramu mogą go zapisać dla wielo¬ 
krotnego użytku instrukcją CSAVE 
( na kasecie) lub SAVE ”D:STA- 
TYST na dyskietce. 

10 GRAPBflCS0:W=200:K=5 

20 DIMA$(1),F$(1),P$(15):A$=CHR$ 

(125) 

30 DIM X(W,K).L(K),S(K),0<K),R(K) 
35 DIM H(¥0>ME(3) 

40 ? A$:? ” OPIS ZMIENNEJ 
JAKOSCIOWEr-.?:? 

45 GOSUB 20000:? A$ 

47 IFR(N)=1THEN?”ZLYTYP 
ZMIENNEJ !”:GOSUB 30000: GOTO 40 

48 IP=1:GOSUB20500:GOSUB 17000 

50 ? A$:POSITION 3,23:?’*DANE 
INNEJ ZMIENNEJ (T>tak,N>nie)” 
;:INPUT F$ _ 

55 IFr$=”N”ORr$=”n”THEN 
? A$:CLR :END 

60 IF F$=”T” OR F$=”t” THEN 40 
65 GOTO 50 
1000 LW=4:?A$ 

1060 ?”. OPIS DANYCH 
JAKOŚCIOWYCH’* 

1540 ON F GOSUB 10000,15000, 
16000,17000 

17000 ?A$:?” OPIS DANYCH 
JAKOŚCIOWYCH”:?:?:? 

17010 ? "PODAJ NUMER ZMIENNEJ 
(I-”;K;”) ”;:GOSUB 30500:IF PF=1 
THEN 17010 

17020 N=VAL(P$):IF N<1 OR N>K 
OR L(N)=0 OR R(N)< = 1 THEN 17010 
17030 POKE621,255:ŁP=R(N): 
GOSUB 21500:LN=L(N):? 

17035 IF LN<4 THEN ? A$:? ”ZBYT 
MAŁA LICZEBNOŚĆ”: GOSUB 
30000:RETURN 

17040 F0RI=lT03iIN=INTa*LN/4) 


17050 IF I*LN/4<>LIN THEN 
ME(I)=H(LIN+l):GOTO 17070 
17060 ME(I)=(H(LIN)+H(LIN+l)y2 

17070 NFITT •"> 

17072 ? "LICZBA OBIEKTÓW: ”;L(N):? 
17075 ? "LICZBA POZIOMOW: 
”;R(N):? 

17080 ? "WARTOŚĆ MEDIANY 
”*ME(2)‘^ 

17090 ? * "ODCH. ĆWIARTKOWE; 
”;(ME(3)-ME(l))/2:GOSUB 
30100:POKE 621,255 
17100 ?” HISTOGRAM DLA ZMIEN¬ 
NEJ NUMER: ”;N:?:?:? 

17200 FORI=0TOR(N):SUM=0 
17210 FOR J=1 TO LN:IF H(J)=I 
THEN SUM=SUM+1 
17215 NEXTJ 
17220 ? "POZIOM: ”;I;” 

LICZBA OBIEKTÓW: ”;SUM 
17230 NEXTI 

17240 GOSUB 30100:RETURN 20000 ? 
:? "NUMER ZMIENNEJ (1-”;K;”)";: 
GOSUB 30500 

20002 IFPF=1 THEN 20000 
20005 N=VAL(P$):IF N<1 OR N>K 
THEN 20000 

20010 ?:? "TYP ZMIENNEJ (1-ILOSC., 
2-JAKOSC.)”;: INPUT F$ 

20012 IF F$<>”1” AND F$<>”2” 
THEN 20010 

20015 R(N)=VAL(F$):IF F$=”l" 
THEN 20030 

20017 ? :? "LICZBA POZIOMOW 
ZMIENNEJ: "•,:GOSUB 30500:IF 
PF=1THEN 20017 

20018 GOTO 20025 

20025 R(N)=VAL(P$):IFR(N)<2 
THEN 20017 

20030 ?:? "LICZBA POMIARÓW 
(OBIEKTÓW): ”;:GOSUB 30500 
20032 IF PF= 1 THEN 20030 
20035 P=VAL(P$):IF P<1 OR P>W 
THEN 20030 
20040 L(N)=P:RETURN 
20500 POSITION 21,3:? "POPRAWKI 
NA KOŃCU!”:? 

20505 FORI=IPTOL(N) 

20510 ? "POMIAR NR ”;I*,” :”;:GOSUB 
30500:IF PF= 1 THEN 20510 
20512 IF R(N)>1 AND VAL(P$) 
>R(N) THEN 20510 
20515 X(I.N)=VAL(P$) 

20520 NEXTI 

20530 ?A$:POSrnON 2,10:? "KONIE¬ 
CZNE POPRAWKI? (T>tak,N>0 
nie)”;:INPUT F$ 

20540 IF F$=”N” OR F$=”xi” THEN 
RETURN 

20545 IFF$<>”T”AND 
F$<>”t” THEN 20530 
20550 ? A$:?:? "POPRAWIANY 
POMIAR NUMER 

20560 GOSMB 30500:IF PF=1 THEN 
20560 

20565 I=VAL(P$):IFI<IPOR 

I>L(N) THEN 20550 

20570 ? :? ” WARTOŚĆ ”;:? X(I,N) 

20580 ? "NOWA WARTOŚĆ ”;:<X)SUB 

30500:IF PF=1 THEN 20580 

20585 IFR(N)>1 ANDVAL(P$)>R(N) 

THEN 20580 

20590 X(I,N)=VAL(P$):GOTO 20530 

20600 GOTO 20530 

21500 FOR 1=1 TO 

L(N):H(I)=X(I,N):NEXT I 

21510 FOR 1=1 TO L(N)- 

1:MN= 1000000000 

21520 FOR J=I+1 TO L(N):IF 
H(J)<MN THEN MN=H(D:V=J 
21530 NEXTJ 

21540 IF Ha)>MN TKN H(V) 

=H(I):H(I)=MN 

21550 NEXTI:RETURN 

30000 POKE621,255:FORI=lTO500: 

NEXT l:POKE 621,0J1ETURN 

30100 POKE 621,0:POSITION 12,23:? 

"NACISNIJ RETURN” ;:INPUT F$:? 

A$:RETURN 

30500 INPUT P$:PF=0:PK=0:IF 
p$=”” THEN 30550:PP=ASC(P$(1,1)) 
30510 F0RJ=(PP=43 0RPP=45)+1 
TO LEN(P$):PW=ASC(P$a,D) 

30520 IFPW=46THENPK=PK+1:IF 

PK>1 THEN 30550 

30530 IFPW<46 0RPW=47 0R 

PW>57 THEN 30550 

30540 NEXTJ:RETURN 

30550 PF=l:SOUND0,110,10,10:FOR 

J=1 TO 50:NEXT J:SOUND 0,Q.0,0:R£- 

TURN 
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O sortowaniu nigdy za 
dużo. Wychodząc z tego 
przeświadczenia pozwa¬ 
lam sobie przedstawić 
efekty analizy pewnego 
prostego i podstawowego 
algorytmu. Załączone pro¬ 
gramy napisane są w MBa- 
sic wers. 5.21 i uruchomić 
je można pod nadzorem sy¬ 
stemu CP/M-2.2. 

Idea wybierania prostego spro¬ 
wadza się do przeglądania tablicy 
A$(x) ze względu na warunek naj¬ 
mniejszego lub największego ele¬ 
mentu. W przykładowym algoryt¬ 
mie (1) przeglądanie odbywa się 
od góry tablicy, element A$(IA+1), 
aż do jej końca, tzn. do A$(IY) i wy¬ 
szukuje się element najmniejszy. 
Następnie zamieniamy ten element 
z A$(IA), obniżamy wskaźnik lA o 1 
i ponownie przeglądamy tablicę. 
Rzecz trwa aż do wyczerpania ele¬ 
mentów tablicy A$(x). 

Każda analiza dowolnego algo¬ 
rytmu sortowania, to w gruncie rze¬ 
czy próba odpowiedzi na pytanie; 
czy nie można szybciej? W przy¬ 
padku algorytmu (1) mogę odpo¬ 
wiedzieć: można. Zamiast przeglą¬ 
dać za każdym razem wszystkie 
pozostałe elementy tablicy należy 
zapamiętać położenie przedostat¬ 
niego najmniejszego elementu i na¬ 
stępne przeglądanie rozpocząć od 
tego miejsca. W efekcie przeglą¬ 
damy tylko ten obszar tablicy 
A$(x), gdzie można spodziewać się 
spełnienia warunku. Zasadę tę rea¬ 
lizuje algorytm (2). 

W linii 330 wskaźnik IB zapamię¬ 
tuje położeme przedostatniego naj¬ 
mniejszego elementu. Wartość 
tego wskaźnika jest losowa i może 
się zdarzyć, że IA=IB, co jest nie¬ 
dopuszczalne dla prawidłowego 
działania algorytmu. Dlatego w 
wierszu 360 umieszczono dodatko¬ 
wy warunek. Pętla przeglądania 
wykonywana jest teraz od elemen¬ 
tu A$(IB) do końca tablicy, tzn. do 
A$(IY). Powninno to spowodować 
przyspieszenie działania algoryt¬ 
mu w porównaniu z (1). Testy to po¬ 
twierdzają - patrz tabelka. 

Testy były prowadzone na zbio¬ 
rze zmiennych tekstowych 4-zna- 
kowych, wygenerowanych losowo 
za pomocą programu - wiersze 900 
do 1030 i zapisanych na dysku. Al¬ 
gorytmy sortowania testowano w 


tablicach 100, 300 i 500-elemento- 
wych przed i po kompilacji. Czasy 
po kompilacji podane są w nawia¬ 
sach. 

Analiza algorytmu (2) nasuwa 
kolejny wniosek, by nie ograniczać 
się przy przeglądaniu do wyszuki¬ 
wania najmniejszego elementu, ale 
jednocześnie wyszukiwać element 
największy. W ten sposób po każ¬ 
dym przeglądaniu ustawiane będą 
2 elementy, u góry i u dołu tablicy 
A$(x). Algorytm (3) jest realizacją 
tego pomysłu. Wiersz 440. to szu¬ 
kanie najmniejszego elementu, 
wiersz 450. - szukanie elementu 
największego. Zastosowano także 
ulepszenia jak w (2), z tym, że ko¬ 
nieczny okazał się dodatkowy wa¬ 
runek w wierszu 550., biorący pod 
uwagę położenie przedostatniego 
największego elementu. Lepsze 
jest wrogiem dobrego - tu właśnie 
potwierdza się ta maksyma. Mimo 
teoretycznie lepszej zasady, algo¬ 
rytm (3) w testach okazuje się zale¬ 
dwie niewiele lepszy od (2) i to tyl¬ 
ko dla dużych zbiorów. 

Na zakończenie proponuję no¬ 
wość w postaci algorytmu (4) - 
"sortowanie polóv/kov/e". Otóż, je¬ 
żeli do posortowania zbioru o N 
elementach potrzeba czasu T, to 
zbiór o N/2 elementach sortuje się 
w czasie T/4. Gdy tablicę A$(x) po¬ 
dzielić na połowę i każdą z połó¬ 
wek sortować oddzielnie, to po¬ 
chłonie nam to T/2 czasu. Realizuje 
to program w wierszach 610-690. 
Następnie potrzebna jest dodatko¬ 
wa tablica B$(x/2) - o połowę 
mniejsza od A$(x). Przepisujemy 
do niej dolną posortowaną połów¬ 
kę tablicy A$(x)-wiersze 700,710. 

Następnie wstawiamy do tablicy 
A$(x) od dołu kolejno: ostatni ele¬ 
ment B$(x/2), po nim ostatni ele¬ 
ment górnej połówki A$(x), nastę¬ 
pnie przedostatni element B$(x/2) i 
przedostatni element górnej połó¬ 
wki A$(x) i tak aż do wyczerpania 
tablicy B$(x/'2) - wiersze 720 do 740. 

Otrzymamy w ten sposób tablicę 
A$(x) z nową zawartością o bardzo 
dużym stopniu uporządkowania. 
Teraz wykorzystać należy najbar¬ 
dziej efektywne w takiej sytuacji 
sortowanie bąbelkowe, aby do¬ 
kończyć dzieła - wiersze 750 do 
770. 

Testy pokazują, że jest to algo¬ 
rytm wcie szybki. 

Należy oczekiwać, że jeszcze 
lepsze wyniki można uzyskać przy 
podziale tablicy na 3 lub więcej 


części. Jednak potrzebna pamięć 
dodatkowa będzie rosła i w skraj¬ 
nym przypadlm osiągnie wielkość 
t^licy podstawowej, a to już przy¬ 
pomina SHELLSORT. 

Ciekawe jest też porównanie 
czasów przed i po kompilacji. Nie 
każdy algorytm doznaje tych sa¬ 
mych przyspieszeń. Na pierwszym 
miejscu jest (4), którego szybkość 
wzrasta 6-krotnie. 


algorytm 

nr 

czas sortowania [s] tablicy N elementowej 

N-lOO 

N-300 

N-500 

1 

43,9(9) 

365(78) 

1010(214) 

2 

40.5(7) 

318(62) 

884(175) 

3 

42 (8) 

310(61) 

861(171) 

4 

34 (5) 

246(39) 

639(109) 


Ps. o sortowaniu pisaliśmy już w "Komputerze" 
w numerach: 4/86, 7'86, 5/87, 7/88. 


A 


' « 

' Test sortowania « 
' 


? “jKk 


1 
2 

3 

4 

5 

6 ' 

le DEFINT I,FiDIM Ax(5ee),B*(25«> 

2« LINĘ INPUT* Zbiór ilu elw»ntow l-se® 

3e IY=VAL(XK);IF IY<1 OR IY>5«e THEN 2® 

99 " 

100 ' wczytanie zbioru 
110 0PEN''r,l,''S0RT.ZB‘' 

120 FOR 1=0 TO lY 
130 INPUTtl,AK(I) 

140 NEXT:CLOSE 

150 PRINTiPRINT" Sortowanie wg (1) lub <2) lub (3) lub (4) 
160 Xj<=INPUTx(1) 

170 IF X)t->'r THEN 200 ELSE IF X*»"2' THEN 300 ELSE IF Xk**' 3'' THEN 400 
ELSE IF Xx=''4'’ THEN 600 ELSE 160 

199 ' 

200 ' (1) wybór prosty 

201 ' 

210 IA=0tUHILE 1A<IY 
230 IX=IA:F0R II=IA+1 TO lY 
240 IF AK(IX))AK(II) THEN IX=II 
250 NEXT 

260 IF IX<>IA THEN SUAP Ak(1A),Ak(IX) 

270 IA=IA+l:WENDsGOTO 850 

299 ' 

300 ' (2) wybór prosty ulepszony 

301 ' 

310 IA=0:IB=IA+ltUHILE IA<IY 

320 IX=IA:F0R II=IB TO lY 

330 IF A*(IX)>A«(II) THEN IB=IX:IX=II 

340 NEXT 

350 IF 1X0 lA THEN SWAP A)t( lA) ,Ax< IX) 

360 IA=IA+liIF IB<IA THEN IB=IA+1 
370 UEND:60T0 850 

399 ' 

400 ' (3) wybór prosty podwojny 

401 ' 

410 IA=0;IB=IA+1:IK*IY:IF Ax(IA>>A>«IK) THEN SUAP Ax(IA) ,A k(IK) 

420 UHILE IB<IK-1 
430 IX=IA:IZ=IKiF0R II=IB TO IK-1 
440 IF AJ<(II><A«(IX) THEN IB=IXiIX=II 
450 IF AK(II)>Ax(IZ) THEN IC=IZ:IZ=II 
460 NEXT 

470 IF 1X01A THEN SUAP Ax(IA) ,Ax( IX> 

480 IF IZOIK THEN SWAP Aw(IK) ,Ak(IZ) 

490 IA=IA+liIK=IK-l 
500 IF IB>IC THEN IB=1C 
510 IF IB<*IA THEN IB-IA+1 
520 UEND:GOT0 850 

600 ' (4) polowkowe 

601 ' 

610 IP=INT(IY/2>:IA-0sIK«IP 

620 IB=IA+1:WHILE IA<IK 

630 IX=IA:F0R II=IB TO IK 

640 IF Ax(IX)>Ak(II) THEN IB«IXjIX=II 

650 NEXT 

660 IF IXOIA THEN SWAP A>« lA) ,Ak(IX> 

670 IA=IA+1#IF IB<=IA THEN IB=IA+1 
680 UEND 

690 IF IK<IY THEN IK=IYiIA=IP+l:GOTO 620 

700 FOR II=IP+1 TO lY 

710 Bx(II-IP-1)=A»((II>jNEXT 

720 IK=IY-IP-ltIJ=0iFOR II=IY TO 1 STEP -2 

730 Ak(II)=Bx(IK-IJ>iAk<II-1)=A*(IP-IJ> 

740 IJ=IJ+1:NEXT 

750 IJ=0sIA=l:FOR II=IY-1 TO IA-1 STEP -1 

760 IF Ax(II>>AW(II+l) THEN SWAP Ax(II),Ax(II+l)xIJ3lsiA=II 

770 NEXTiIF U THEN 750 

840 ' 

850 PRINT CHRx<7)+'' KONIEC "iGOTO 20 
890 ' 

900 ' generator znokow 
910 FOR II»0 TO 500 
920 Bx="':F0R IJ=1 TO 4 
930 IX=IJ 

940 IA=INT(100*RND(IX>) 

950 IF IA<65 OR IA>90 THEN IX-IX+1:G0T0 940 
960 Bk=Bk-H:HRx(IA) 

970 NEXT IJ:Ax<II>=Bx;PRINT Bx 
980 NEXT II 

990 0PEN"0*',1,"S0RT.ZB“ 

1000 FOR 11=0 TO 500 
1010 URITEfl,Ax<II) 

1020 NEXTiCL0SE 
1030 END 
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Rozkosze łamania palców 
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Programiki 

dla Atari XE/XL 


Na wstępie chciałbym podzię¬ 
kować wnikliwym Czytelnikom Ja¬ 
nuszowi Baczyńskiemu i Marci¬ 
nowi Nowackiemu za zwrócenie 
uwagi na błęd w zapisie programu 
"RAINBOW” (nr 7/88). W wierszu 
60 przedostatnia wartość powinna 
wynosić 96 (RTS assemblera), a nie 
196. Teraz po naciśnięciu START 
program będzie powracał do Basi- 
ca. Niestety w t^ odcinku cyklu 
Chochlik szalał aż miło i o pewne 
poprawki w publikowanym pro¬ 
gramie poprosił p. Matlęga. Poni¬ 
żej zamieszczamy poprawny zapis 
wierszy: 

2 P=(3*A*W^2 + 2*B*W+C)/ 
A:Q=(A*W^3-hB*W^2+C* 
W+D)/A: WR=Q^2/4+P^ 3/22 
12 FI=PI+ATN(SQR(Y*(-2)- 
1)):?”X1 = ”; INT((W+2*SQR(-P/ 
3)*COS(FF3))*100)/100 
13?”X2=”;INT((W -h 2*SQR(-P/3)* 
COS(FI/3 + (2 *PI)/3))* 100)/100 
14?”X3=”;INT((W+2*SQR(-P/3)* 
COS(FI/3 + (4*PI)/3))* 100)/ 
100:END 

15?”X1 =”;INT((W-2*(Q/2)M1/ 
3 ))* 100 )/ 100 : 

?”X2=X3=”;INT((W+(Q/2) ^(1/ 
3))*100)/100 

Czytelników przepraszam za 
błędy. Przedstawiam nowe ”kró- 
ciaki”. Przemek Kucharzewski 
przesłał do redakcji dwa progra¬ 
my, jeden z nich miał być przezna¬ 
czony do rub^ki "Forum”, bo prze¬ 
kracza przepisowe 15 wierszy, lecz 
postanowiłem "ukraść” go dla 
"Programików". Zapewne zauważę 
Państwo, że nie ma żadnego pro¬ 
blemu z takim zapisem tego pro¬ 
gramu, aby numer ostatniej linii nie 
przekraczał 15, jednak dla przej¬ 
rzystości postanowiłem pozosta¬ 
wić go w formie przysłanej przez 
autora. Proępram "KLAWISZE" roz¬ 
szerza możliwości edytora Basica. 
Po naciśnięciu klawisza SHIFT 
wraz z jednę z wymienionych liter 
zostanę wyświetlone na ekranie 
odpowiednie instrukcje Basica. 
SHIFT R... RUN 
SHIFT L... LIST 
SHIFT O... POKE 
SHIFT P... PEEK( 
SHIFT N... NEW 
SHIFT X... DATA 
SHIFT C... CLOAD 
SHIFT V... CSAVE 
SHIFT ?... PRINT 
SHIFT W... GRAPHICS 
SHIFT E... GOSUB 
SHIFT I... POSITION 
SHlfT D... DRAWTO 
SHIFT G... GOTO 
SHIFT K... PLOT 


Program został zapisany na 6 
stronie pamięci jako translacja 
asemblera na Basic. Program źró¬ 
dłowy napisał Przemek w Makroa- 
semblerze ATMAS II wykorzystu- 
jęc przerwania klawiatury. Po naci¬ 
śnięciu dowolnego klawisza pro¬ 
gram sprawdza czy nie była to jed¬ 
na z wymienionych kombinacji, je¬ 
żeli TAK, to wyświetla na ekranie 
odpowiednię instrukcję Basica. 
Program nie jest odporny na RE- 
SET, ale można go wywołać pono¬ 
wnie przez ?USR(ł536). Na zakoń¬ 
czenie jeszcze jedna uwaga: w pro¬ 
gramie pisanym przy użyciu "Kla¬ 
wiszy” nie wolno używać komórek 
pamięci 203, 204 i 205, gdyż pro¬ 
gram rezerwuje je jako rejestry 
przejściowe. Nie będziemy publi¬ 
kowali Państwu programu w asem¬ 
blerze^ gdyż zainteresowani nie 
będę mieli problemu z otrzyma¬ 
niem programu źródłowego (w 
opisany w poprzednich odcinkach 
sposób). 

10 ? CHRS(125):? :? ” (c) 1988 Przemy¬ 
sław Kucharzewski”:? : ? CHR$(127);” 

Proszę czekac.” 

20 S=0:FOR A=1536 TO 1692:READ 
Q:S=S+Q:POKE A,Q:NEXT A 
30 IF S015225 THEN ? 
CHR$(253);”BIiAD W LINIACH 
DATA!”:END 
40 X=USR(1536) 

45 REM KOD MASZYNOWY 
50 DATA 104,120,169,14.141,8,2,169,6 
60 DATA 141,9,2,88,96,162,0,189,142 
70 DATA 6,205,9,210,240,8,232,224 
80 DATA 15,208,243,76,25,252,134,203 
90 DATA 165,203,101,203,101,203,101 
100 DATA 203,101,203,168,136,105,4 
110 DATA 133,205,185,67,6,132,204,32 
120 DATA 176,242,164,204,200,196 
130 DATA 205,208,241,104,64 
135 REM WYŚWIETLANIE 
INSTRUKCJI BASICA 
140 DATA 82,85,78,32,32,76,73,83,84 
150 DATA 32,80,69,69,75,40,80,79,75 
160 DATA 69,32,71,79,84,79,32,71,79 
170 DATA 83,46,32,80,79,83,46,32,71 
180 DATA 82,46,32,32,80,76,79,84,32 
190 DATA 68,82,65,87,46,68,65,84,65 
200 DATA 32,67,76,79,65,68,67,83,65 
210 DATA 86,69,80,82,73,78,84,78,69 
220 DATA 87,32,32 
225 REM KODY KLAWISZY 
230 DATA 104,64,74,111,125,106,77,110 
240 DATA 69,122,86,82,80,102,99 

Drugi z przysłanych przez Prze¬ 
mka programów był już przezna¬ 
czony dla naszej rubryki i muszę 
przyznać, że z dużę przyjemnościę 
zaprezentuję go Państwu. Program 
jest bardzo prosty, jest to właściwie 
demonstracja, jechiak procedury 


zawarte w tych kilku wierszach na 
pewno z radościę dołęczę Państwo 
do swoich programów. "Rury” to 
program rysujęcy tytułowe przed¬ 
mioty w 9 grafice w 16 odcieniach, 
co oczywiście daje złudzenie trój¬ 
wymiarowości. 

0 GRAPHICS 9 

10 C=0:X=RND(0)*63:Y=RND 
(0)*160 

20 FORA=YTOY+29 
30 IFA<Y+15THENC = C+1 
40 IFA>Y+14THENC=C-1 
50 COLOR C:PLOT 0,A: 

DRAWTO 79,A:NEXT A 
60 C=l:FORA=XTOX+16 
70 COLOR C:PLOT A,0: 

DRAWTO A,190 
80 IFA<X+8 THEN C=C+1.8 
90 IF A>X+7THENC=C-1.8 
100 NEXT A:GOTO 10 
Procedura rysowania rur w tym 
programie jest na tyle prosta, że nie 
widzę konieczności jej opisywania. 

Kolejny program nadesłany 
przez Witolda Kolasę z Warasza- 
wy tworzy na tle grafiki okienka, 
które po ponownym wywołaniu 
pozostawiaję na ekranie stan pier¬ 
wotny. Utworzone okienka mogę 
zawierać dowolne dane: tekst, gra¬ 
fikę, wyświetlane z rozdzielczościę 
właściwę dla danego trybu graficz¬ 
nego. Możemy także przez kilka¬ 
krotne wywołanie procedury z róż¬ 
nymi danymi utworzyć kilka okie¬ 
nek (Uwaga! Przy kasowaniu okie¬ 
nek należy zachować odpowiednię 
kolejność). Utworzone okienka 
mogę być różnej wielkości i w róż¬ 
nych miejscach ekranu, a także 
mogę na siebie zachodzić. Głównę 
procedurę programu ulokował Wi¬ 
tek na poczętku szóstej strony pa¬ 
mięci, wykorzystujęc także komór¬ 
ki $00, $01, $CB-$D1 na stronie ze¬ 
rowej. Zamieszczony poniżej pro¬ 
gram oprócz głównej procedury w 
assemblerze (linie 10-60) zawiera 
także część demonstracyjnę. 

10 FOR 1=1536 TO 1629:READ 
AiPOKE I,A:NEXT I 
20 DATA 104,201,5,208,88,104,133, 
204,104,133,203,104,133,206,104, 
133,205,104,104,133,207 
30 DATA 104,104,133,208,104,104, 
133,209,169,0,133,0,160,0,196,207, 
176,16,177,205,133 
40 DATA 1,177,203,145,205,165,1, 
145,203,200,76,35,6,165,0,197,208, 
176,32,216,24 

50 DATA 165,205,101,207,133,205, 
165,206,105,0,133,206,24,165,203, 
101,209,133,203,165,204 
60 DATA 105,0,133,204,230,0,76,33, 
6,96 

70 DIM0KN01$(615),0KN02$ 
(615):GRAPHICS 7: DL=DPE- 
EK(560): AE=DPEEK(DL ^ 4) 

80 COLOR IrPAINT O.OiCOLOR 2:’ 
45 ""-."OKNO 1”:GM=20:LM=10: 
AO=ADR(OKN01$):GOSUB 140 
90 COLOR 2:PAINT 45,35:COLOR 
1:’ 45,35,"OKNO 2”: AO=ADR(OK- 
N02$):GOSUB 140 
100 GRAPHICS 7:’ 50,35,”TLO”:? 

:? ” NACISNIJ DOWOLNY laA- 
WISZ”' 

110 GM=20:LM=10:AO=ADR 
(OKN01$):GOSUB 140:GET I: 

GM=30:LM = 15:AO=ADR(OK- 
N02$):GOSUB 140:GET I 
120 GOSUB 140:GETI:GM=20: 

LM= 10:AO=ADR(OKN01$): 
GOSUB 140:GET LGOTO 110 
130 END 

140 X=USR(1536,AE+GM* 

40+LM,AO,15,40,40):RETURN 


Teraz należy się Państwu kilka 
słów wyjaśnienia. Zapewne zauwa¬ 
żyli Państwo, że program napisany 
jest w Turbo Basicu XL, czyli naj¬ 
pierw należy wprowadzić interpre¬ 
ter tego języka, a dopiero potem 
wpisać powyższy zapis. Wyjaśnie¬ 
nia wymaga także postać i parame¬ 
try instrukcji wywołujęcej proce¬ 
durę tworzenia okna: 

X=USR(1536,AE-ł-GM* 
ILB+LM,AO,SZ,WY,ILB) 
gdzie: 

AE...poczętek pamięci ekranu dla 
danego trybu 

GM...górny margines okna w li¬ 
niach ekranowych 
LM...lewy margines okna w "baj¬ 
tach” 

ILB..ilość bajtów na linię w danym 
trybie graficznym 
AO...poczętek pamięci okna 
SZ.,.szerokość okna w "bajtach” 
WY...wysokość okna w liniach 
ekranowych 

AE+GM*ILB - adres lewego gór¬ 
nego rogu okna w pamięci ekranu. 
Dla uproszczenia dane okna mogę 
być zapisane w tablicy tekstowej, 
wtedy AO=ADR(nazwa tablicy). 
Natomiast aby znaleźć poczętek 
pamięci ekranu (AE) należy naj¬ 
pierw sprawdzić położenie Dis¬ 
play List: 

DL=PEEK(560) + 256*PEEK(561), 
i odczytać właściwę wartość z 4 i 5- 
ego bajtu DL, czyli 
AE=PEEK(DL4-4)+256* 
PEEK(DL+5). 

Na zakończenie mała niespodzian¬ 
ka dla elektroników, dwa krótkie 
programiki napisane przez Janu¬ 
sza BacfZyńskiego z Kielc. Autor 
ma nadzieję, że okażę się one po¬ 
mocne przy regulacji telewizorów. 
Pierwszy z nich wyświetla na ekra¬ 
nie dziewięć różnokolorowych pa¬ 
sów i generuje sygnał PAL (1000 
Hz), może się on okazać przydatny 
przy uruchamianiu dekoderów. 

10 GRAPHICS 10 

20 POKE 704,12:POKE 705,8:POKE 
706,86:POKE 707,52 
30 FORI=0TO8:K=I+2-9*INT 
((I+l)/8):COLORK 
40 FORJ=0TO7:PLOTI*8+J+5,0: 
DRAWTO I*8+J+5,191:NEXT 
J:NEXT I 

50 SOUND 0,319,14,15 
6 GOTO 60 

Drugi z programów pozwala 
ocenić liniowość i zbieżność tele¬ 
wizora dzięki możliwości analizy 
pojawiajęcego się obrazu kraty. 
Używajęc klawiszy R, G, B mamy 
możliwość oceny czystości kolo¬ 
rów. 

10 K=PEEK(764);IFK=40THENC=3: 
GOTO 70 

20 IFK=61 THEN C= 12:GOTO 70 
30 IFK=21THENC=7:GOTO70 
40 GRAPHICS 30:SETCOLOR 0,0,10: 
COLOR 1 

50 FOR *1=1 TO 159 STEP 12:PLOT 
0,I:DRAWTOI,191:NEXTI 
60 FOR 1=5 TO 191 STEP 20:PLOT 
0,I:DRAWTO 159,I:NEXT I 
70 GOTO 90 

80 GRAPHICS 19:SETCOLOR 4,C,6 
90 IFK=PEEK(764)THEN90 
100 GOTO 10 

To już wszystko w dzisiejszym od- 
cinloi "Programików", myślę, że 
Czytelnicy nie wezmę mi tego za 
złe, że dwa ostatnie programiki po¬ 
zostawię bez żadnego komentarza. 

m 
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ATARI XE/XŁ 

Arkadiusz Lew-Kiedrowski, 

uczeń IV klasy matematycznej IV 
LO im. T. Kościuszki w Toruniu, 
znalazł sposób na ukończenie PRE- 
LIMINARY MONTY 16K dla Atari 
800 XL. W grze tej bohater ma tylko 
pięć wcieleń, co jest dość istotnym 
utrudnieniem w swobodnym poru¬ 
szaniu się po labiryncie. Po naszej 
interwencji każdy błąd przyniesie 
nam korzyść. 

Pod kontrolą dowolnego monito¬ 
ra wgrywamy główną część pro¬ 
gramu pod adres nn. W komórce 
nn+$3262 znajduje się rozkaz DEC 
$88 ($C6, $88). Wpisujemy tam 
wartość $E6 zmieniając tym saunym 
zmmejszanie licznika na zwiększa¬ 
nie - rozkazem INC $88. Od tej 
pory bohatera chroni potężny czar 
Montezumy, zapewniający mu 
nieśmiertelność i nie powodujący 
żadnych przyk^ch konsekwencji 

Viidvvei żaóuizeń pizy y^swieilaniu 

aktualnego wyniku). 

W grze możemy również wybrać 
stopień trudności (klawisz SE- 
LECT). Komputer jednak nie bar¬ 
dzo wierzy w nasze siły i oferuje co 
najwyżej trzeci poziom. Najlepiej 
przekonamy go o naszych możli¬ 
wościach wpisując wartość 9 pod 
adres nn+$2B9B (11162 dziesięt¬ 
nie), czym zamienimy rozkaz CMP 
#3 na CMP #9. To spowoduje, że 
komputer potraktuje nas poważnie 
i od tej chwili będziemy mogli roz¬ 
poczynać grę na dowolnym, wy¬ 
branym poziomie. 

Poprawianiem gier dla Atari 
XE/XL zajmuje się różwnież Grze¬ 
gorz Tarczyński, uczeń I klasy XII 
LO we Wrocławiu. Do wprowadza¬ 
nia modyfikacji używa on programu 
Disc Wizard n. Po wgraniu progra¬ 
mu monitora należy odszukać w in¬ 
teresującej nas grze podany ciąg ro¬ 
zkazów i zmienić go. Poprawki 
mogą wprowadzać zarówno posia¬ 
dacze stacji dysków, jak i magneto¬ 
fonów. 

W CHUCKIE EGG poszukujemy 
ciągu liczb heksadecymalnych 
(A9,05,99,00,52) odpowiadających 
rozkazom 

LDA #$05 
STA $5200, Y 

i zamieniamy 05 na FF, co da nam 
255 istnień. 

Również w MR ROBOT odnaj¬ 
dujemy (A9,05,85,C4) - czyli 
LDA #$05 
STA $C4 

Zwiększamy odporność na kolizje 
przez wpisanie 63 zamiast 05. 

W BC’S OUEST FOR TIRES po 
szukujemy ciągu (A9,05,8D,0A,0E) i 
zamieniamy 05 na 80. 


WELCOME TO BATTY - znaj¬ 
dujemy (A9,05,85,8B). Uzyskamy 99 
wcieleń po wpisaniu 63 zamiast 05. 
Odpowiednie rozkazy będą miały 
teraz postać 
LDA #$63 
STA $8B 

Podobną modyfikację wprowa¬ 
dzamy do HYPER OLYMPIC. Od¬ 
najdujemy (A9,02,85,27) i piszemy 
63 w miejsce 02. 

Jeszcze jeden zestaw poprawek 
gier dla Atari nadesłał Michał Bor¬ 
kowski z Wrocławia. Postępuje¬ 
my tak jak poprzednio i dla AIR 
WOLF poszukujemy ciągu bajtów 
(CE,FF,06), gdzie poprawiamy CE 
na AD. 

W AŁLEY CAT znajdujemy baj¬ 
ty CE,A5,02, które występują czte¬ 
rokrotnie i za każdym razem za¬ 
mieniamy CE na AD. 

ZYBEX! - odszukujemy ciąg baj¬ 
tów CE,7F,3C dla pierwszego gra¬ 
cza oraz CE,88,3C dla drugiego i 
wpisujemy AD zamiast CE. Powyż¬ 
sze modyfikacje dają nam ulubione 
"wieczne życie”. 

ACTION BIKER to zabawa w 
wyścigi motocyklowe. Możemy 
powiększyć swoją stajnię po znale¬ 
zieniu ciągu liczb (4B,45,53,3A,35) i 
wpisaniu FF w miejsce 35. 

Wiele gier ma ukryte tylne wejś¬ 
cie tzw. cheat modę, czyli pozosta¬ 
wione przez autorów hasło pozwa¬ 
lające na zmianę parametrów gry. 
W grach MIRAX FORCE i HEN- 
RY*S HOUSE, po załadowaniu pro¬ 
gramu i pokazaniu się tytułowej 
planszy, należy wpisać inicjały au¬ 
tora: CPM. Wówczas statek staje 
się niezniszczalny, a Henry nieś¬ 
miertelny. 

CRUMBLES CRISIS - tutaj Mi¬ 
chał proponuje sztuczkę pozwala¬ 
jącą na zmianę początkowego 
układu (tylko dla wersji dyskowej). 
Możemy odpowiednio zamienić 
nazwy zbiorów MAP2 (lub MAP3, 
MAP4, MAP5) na MAPI i jednocze¬ 
śnie BI (lub Cl, Dl, El) na Al, gdzie 
B1 łączymy z MAP2, C1 z MAP3, itd. 
Musimy tylko pamiętać, by wcześ¬ 
niej zmienić istniejące już nazwy 
MAPI, Al na dowohie tak, by nie 
powstały zbiory o tej samej nazwie. 

ŻX Spectrum 

Spectrum coraz rzadziej gości na 
naszych łamach - szkoda, jest to 
dobry komputer. Dziś dwóch wła¬ 
mywaczy i dwie gry. 

Pierwszy z nich to Wojciech Żół- 
kiewicz z miejscowości Rumia Ja¬ 
nowo, który proponuje oszukanie 
gry GAUNTTjET. Na początku wy¬ 
bieramy sterowanie dla pierwsze¬ 
go gracza na KEMPSTON, a dru¬ 
giego na KEYBOARD i wgrywamy 
pozostałe części. Po uruchomieniu 
gramy aż do wyczerpania energii. 
Wówczas naciskamy FIRE za dru¬ 
giego gracza. Po śmierci pierwsze¬ 
go zabieramy to co po nim zostało 
(brzmi to trochę makabrycznie) i 
grauny dalej. Gdy skończy się ener¬ 
gia drugiego gracza, naciskamy 
FIRE w joysticku, itd., itd. 

Nie miiem okazji bawić się tą 
grą i nie wiem jak wyglądają szczą¬ 
tki gracza, ale mam nadzieję, że 
drodzy Czytelnicy poradzą sobie z 
tym i nie stracą apetytu. Podobno w 
ten sposób możemy grać w nies¬ 
kończoność. 

Tadeusz Bąk z VIIIb Szkoły Pod¬ 
stawowej nr 109 w Warszawie na- 


* * * * A A * A A * Jk * AAAAAAAAAAAAAAAAAAAAAAAAAA 
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* Funkcja 36: Ustaw rekord swobodny 

* (SET KANIX»f KECOId)) 




Paraaetry wejściowe: 

Rejestr C: 
Rejestry DE: 


24H 

adres FCB 


Wartość zwracana: 

Ustawione pole rekordu 
swobodnego 


** *««***««* <k ** M *********** *********** * 

Funkcja 36 powoduje automatyczne 
określenie przez BDOS i>ozycji rekordu 
swobodnego należącego do zbioru, który jest 
czytany lub pisany sekwencyjnie w 
określone miejsce. Funkcja może być 
używana na dwa sposoby. 

W pierwszym, często jest konieczny 
"inicjujący" odczyt i badanie zbioru 
sekwencyjnie, aby wydzielić pozycje różnych 
pól "kluczowych". Gdy odnalezione są 
wszystkie klucze, wywoływana jest funkcja 
36 dla obliczenia pozycji rekordu w 
dostępie swobndnvm odnowiadalacewo i-v« 

kluczom. W efekcie pozycja rekordu 
wynikowego może zostać umieszczona w 
tablicy z kluczami dla późniejszego 
wykorzystania. Po przeszukaniu całego 
zbioru, zgromadzeniu kluczy i 
odpowiadających im numerów rekordów w 
tablicy, użytkownik może natychmiast użyć 
rekordu określonego kluczem przez 
zastosowanie -czytania swobodnego, 

wykorzystując odpowiedni numer rekordu, 
który został wcześniej ' określony. ' Ten 
sposób postępowania -można łatwo uogólnić 
dla różnych długości rekordów, ponieważ 
program musi przez cały czas pamiętać 
tylko względną poeycję bajtu wraz z 
kluczem i numerem rekordu dla odnalezienia 
w przyszłości dokładnej pozycji początkowej 
danych dostępnych za pomocą klucza. 

Drugi przypadek użycia funkcji 36 
zachodzi podczas przełączania z cz}rtania 
lub pisania sekwencyjnego na czytanie lub 
pisanie swobodne. Zbiór jest obsługiwany 
sekwencyjnie do określonego punktu, a 
następnie wywoływana jest ftmkcja 36, 
która ustala numer rekordu, a kolejne 
operacje czytania i pisania swobodnego 
kontynuowane są od następnego rekordu. 
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* * 

* Fuokcja 37: Zerowanie jednostki • 

* dyskowej • 

* (RESET I»IVE) * 

* * 

***************************************** 
* * 

* Parametry wejściowe: * 

* Rejestr C: 25H * 

* Rejestry DE: wektor jednostki * 

* dyskowej * 

* * 

• Wartość z¥nracana: * 

• Rejestr A: OOH • 

• * 

***************************************** 

Funkcja "Zerowanie jednostki dyskowej" 
umożliwia ustawienie wariuików 

początkowych określonych jednostek 

dyskowych. Paranetreo wejściowym jest 16- 
bitowy wektor jednostek dyskowych^ które 
mają być zerowane; najmniej znaczący bit 

wektora oznacza jednostką A. Dla 

2 :apewnienia kompatybilności systemu CP/M z 
systemem HP/Ht w rejestrze A przekazywana 
jest wartość zero. 

Funkcja nie zawsze opisywana w 

podręcznikach źródłowych. 

t I - _ _ 

***************************************** 
* * 

* Funkcja 38: nie używana • 

* Funkcja 39: nie używana * 

* * 

***************************************** 

***************************************** 
* * 

* Funkcja 40: Pisanie swobodne z uprzed-* 

* nim zerowaniem * 

* (WRITE RANDOM WITH * 

* ZERO FILL) * 

***************************************** 

* * 

* Parametry wejściowe: ^ 

* Rejestr C: 28H * 

* Rejestry DE: adres FCB * 

* * 

* Wartość zwracana: * 

* Rejestr A: kod powrotu * 

* * 

***************************************** 

Fvmkcja 40 jest podobna do funkcji 34 z 
tą różnicą^ że nieulokowany blok 

wypełniany jest zerami zanim rozpoczenie 

Sie pisanie danych. 
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pisał nam jak poprawić jedną ze 
starszych gier - ASTRO BLASTER 
Komendą LOAD” ” wgrywamy pro¬ 
gram, wybieramy sposób sterowa¬ 
nia i zaczynamy strzelaninę. 

Musimy zdobyć ponad 200 pkt., 
tak, by zyskać prawo wpisania się 
na listę najlepszych strzelców. Na¬ 
ciskamy wówczas klawisz T, czyli 
RANDOMIZE. Na dole powinien 
pokazać się komunikat 

0 OK, 40:1 

Kolejno LIST, ENTER i ukazuje się 
następujący program ładujący: 

10 CLEAR 32767 

20 POKE 23613,87 

30 SAVE "ASTRO” CODĘ 
23570,7600 

40 RANDOMIZE USR 26368 
Teraz w linii 40 przed komendą 
RANDOMIZE dopisujemy następu¬ 
jące poprawki 

POKE 27422,0 : POKE 26396,255 
Uzyskujemy w ten sposób nieś¬ 
miertelność, która jednak przesta¬ 
nie działać, gdy zestrzelimy kokon 
rozrzucający bomby. 

Sposób wprowadzenia modyfi¬ 
kacji jest równie archaiczny jak 
sama gra i nie jestem pewien czy 
skuteczny. 

COMMODORE C64 

Marcin Zabraniak ze Szczeci¬ 
na przesyła kilka poprawek do 
gier przeznaczonych dla wciąż po¬ 
pularnego Commodore. 

Pierwsza z nich to FORT APO¬ 
KALIPSĘ, gdzie celem gry jest za¬ 
branie wszystkich ludzi z podziemi, 
zniszczenie generatora i powrót do 
bazy. Po wpisaniu: 

POKE 36366,0: 

ł ^nr\n r\ - 
rWiVJL l^Dv7i,U : 

POKE 14760,0 

uzyskujemy wieczne życie, zatrzy¬ 
manie upływu czasu w grze i nasz 
helikopter nie będzie zużywał cen¬ 
nego paliwa. 

Również wieczne życie uzyska¬ 
my w trzech kolejnych grach: 
DIG-DOG - 

POKE 10775,234 
POKE 10776,234 
ZEPPELIN - 

POKE 18546,234 
POKE 18547,234 
POKE 18548,234 
OUEST FOR TIRES - 
POKE 14864,0 

Celem tej ostatniej jest uwolnienie 
narzeczonej z łap smoka. 

Publikowana wcześniej popraw¬ 
ka do JET SET WILLY ma, według 
Mariusza, skutki uboczne i propo¬ 
nuje on inną 

POKE 14561,165 

Efekt - "nieśmiertelność” i gra 
działa poprawnie. 

Ten sam skutek będą miały mo¬ 
dyfikacje dwóch następnych gier. 
Pierwsza to BLACK HAWK 
POKE 8427,234 
POKE 8428,234 

Druga zaś to WHO DARES WIN II, 

gra podobna do popularnego 
Commando lecz bardziej urozmai¬ 
cona. Wpisujemy: 

POKE 6566,234 
POKE 6567,234 
POKE 15273,234 
POKE 15274,234 
POKE 15275,234 

Poza "wiecznym życiem" poprawki 
te dają nam nieograniczony zapas 
granatów. 

A Swoimi osiągnięciami w dziedzi¬ 



nie "ulepszania” gier dzieli się rów¬ 
nież Marek Drozdowski z Pozna¬ 
nia (lat 16). 

BALL GRAZY 

po zresetowaniu komputera wpi¬ 
sać SYS 32784 i mamy nieśmiertel¬ 
ność 

MARIO BROTHERS 

wystarczy wpisać tę procedurkę, 
uruchomić, wczytać grę i mamy 
nieśmiertelność 

10 FOR 1=53229 TO 53256:READ A:P0KE 
1,A:C=C+A:NEXT: 

20 1FC=3204THEN SYS 53229 
30 PRINT ”BLAD W DANYCH”:END 
40 DATA 198.157,169,0,162,1,168.32,186255, 
32,189,255,32,213,255,169,208,141 
50 DATA 146,4,96,14,042,76,3,1 
MAGMAX 

pomożemy trochę staremu Maxowi i damy 
mu nieśmiertelność 

20 FOR A=53229 TO 53260:READ B:P0KE 
ĄB:NEXT 
30 SYS 53229 

40 DATA 32,44,247,32,108,245,169,0,141,239 
50 DATA 3,169,208,141,244,3,76,167,2,169 
60 DATA 60,141,87,3,169,141,88,3,76.0,8 

FROSBYTE 

wczytać, zresetować, potem Poke 4388,165 
(nieśmiertelność) i uruchomić przez SYS 
2825 

KRAKOUT 
Poke 35223,234 
Poke 35224,234 
Poke 35225,234 
Poke 35262,234 
Poke 35263,234 
Poke 35264,234 
SYS 32837 
WIZBALL 

meśmiertelność da nam ten programik: 

10 FOR 1=53229 TO 53258:READ A:POKE 
1,A:C=C+A:NEXT 
20 IFC=3031THEN30 
25 PRINT ”BLAD W DANYCH”:END 
30 SYS 53229 

40 DATA 32,44,247,32,108,245,169,208,141, 
62,50 

50 DATA 4,76,99,3,169,96,141,39,107,238, 
32,208,76,80,0 

EAGLES 

20 FOR A=53216 TO 53255:READ B:POKE 
A,B:NEXT 
30 SYS 53216 

40 DATA 32,44,247,32,108,245,169,76 
50 DATA 141,209,3,169,248,141,210,3 
60 DATA 169,207,141,211,3,76,174,2 
70 DATA 169,96,141,7,163,141,62,163 
80 DATA 169,173,141,229,162,76,24,8 
IBALL 
Poke 20669,238 
SYS 16939 
METRO CROSS 

program ten da nam niekończący się czas 
20 FOR A=53229 TO 53255READ 
B:P0KE A,B:NEXT 
30 SYS 53229 

40 DATA 32,44,247,32,108,245,169,0,141,142 
50 DATA 8,169,208,141,143,8,76,16,8,169,96 
60 DATA 141,185,52,76,234,3 
SHADOWSKIMMER 
20 FOR A=35721 TO 35766:READ BPOKE 
A,B:NEXT 

30 F0RA=53248T0 53255:READB:P0KE 
A.B:NEXT 
40 SYS 3572 

50 FOR Z=679 TO 767:POKE Z,(PEEK(Z+ 
8192)):NEXT 

60 FORZ=828TO!!(@:POKEZ,(PEEK(Z 
+8192)):NEXT 
70 SYS 1024 

80 DATA 32,44,247,169,34,141,62,3,169 
90 DATA 48,141,64.3,32,108,245,169,32 
100 DATA 141,222,35,169,169.141,223,35 
110 DATA 169.139,141,224.35,96,169.0.141 
120 DATA 143,8.169,208.141,144,8,238,32 
130 DATA 208,96,174,141,252,74,76.14,8. 

1] 
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Input-output 



PĘTLICZEK - bo pętla jest podstawą programowania. Tu znajdziesz 
kolejną porcję zadań naszego Klubu Mistrzów Komputera. 


MĘTLICZEK — bo znajdziesz tu różne różności, związane z minikom¬ 
puterem tak cienką nitką, że Redakcja już nie bierze za nią odpowie¬ 
dzialności. 

Redakcja strony klubowej: Marcin Jędrzejewski, Leszek Rudak. 


ZADANIA 

KLUBOWE 



13/89. Proponuję napisać pro¬ 
gram rysujący na ekranie schemat 
podanego związku chemicznego. 
Oczywiście zadawalającym roz¬ 
wiązaniem będzie program rozpo¬ 
znający tylko proste związki nieor¬ 
ganiczne - schemat DNA jest chy¬ 
ba zbyt skomplikowany... 

LR 

14/89. Działaniem oiarnym na¬ 
zywamy funkcję dwuargumento- 
wą, której argumenty i wartości po¬ 
chodzą z tego samego zbioru. Dzia¬ 
łania mają wiele ważnych własnoś¬ 
ci (np. przemienność, łączność). 

prGyr5.ni 

sprawdzający czy dane działanie 
określone w zbiorze skończonym 
jest przemienne, tzn. czy wynik 
tego działania nie zależy od kolej¬ 
ności argumentów. 

LR 

15/89. Czasami zapominamy 

wyłączyć magnetofon po wczyta¬ 
niu programu. Aby zapobiec temu 
proponuję napisać program kon¬ 
trolujący operacje na pamięci zew¬ 
nętrznej i sygnalizujący zakończe¬ 
nie operacji (np. dźwiękiem). Pro¬ 
gram ten powńnien dzi^ać niezale¬ 
żnie od innych programów, 
(zadanie nadesłał Piotr Ryszkie- 

wicz) 


STOP! 

Programy komputerowe, które 
liczą powinny podawać wyniki 
obliczeń wtedy, gdy mają one jesz¬ 
cze jakieś znaczenie. Można sobie 
bowiem wyobrazić program roz¬ 
wiązujący pewne zadanie, np. z ką¬ 
cika "Rozkosze łamania głowy” z 
"Życia Warszawy", tak długo, że 
wynik otrzymamy po terminie nad¬ 
syłania rozwiązań. Jest on wtedy 
oczywiście bezużyteczny. Każdy, 
kto próbuje zastosować komputer 
do rozwiązywania zadań spotyka 
się z problemem stopu, to znaczy z 
pytaniem: czy program skończy 
kiedyś działać? Mnie takie pytanie 
nurtuje zwykle wtedy, gdy po kil¬ 
kunastu minutach komputer nic nie 
wyświetla na ekranie, nic nie dru¬ 
kuje, nie czyta z dysku, ale też nie 
reaguje na naciskanie klawiszy na 
klawiaturze. Oczywiście, pisząc 
program zawsze staram się prze¬ 


widzieć czas potrzebny na wyko¬ 
nanie wszystkich instrukcji. Póź¬ 
niej, gdy komputer znacznie prze¬ 
kroczy ten czas, to wiem, że "się za¬ 
wiesił”. Staram się także unikać in¬ 
strukcji postaci: 
while tnie do; (w Pascalu) oraz 
100 GOTO 100 (w Basicu) czy 
for(i= l;i<2;); (w języku C). 

Gdy w tekście programu znaj¬ 
dzie się instrukcja podobna do 
przedstawionych wyżej, to można 
stwierdzić, że program nigdy się 
nie zatrzyma, a więc w takim przy¬ 
padku "problem stopu" mamy roz¬ 
wiązany. Niestety negatywnie. 

Są jednak przypadki, gdy z sa¬ 
mej formy programu nie można 
przewidzieć czy obliczenia kiedy- 

• i^Ci7viek zakończą się, nie da się 
nawet oszacować czasu obliczeń. 

Proszę przyjrzeć się następują¬ 
cemu programowi: 

program licz; 
var iiinteger; 
begin 

write(’Podaj liczbę: ’); 

read(i); 

while iol do 
if i mod 2=0 
then i:=i div 2 
else i:=3*i+l; 

end. 

O ile mi wiadomo nie ma odpowie¬ 
dzi na pytanie czy dla każdej liczby 
program ten skończy działanie. 
Przypuszczalnie tak, ale to tylko hi¬ 
poteza, lecz nieudowodniona. Nie 
wiadomo również jak długo trzeba 
czekać na wyniki. 

Dla wszystkich, którzy używają 
komputera naturalne wydaje się 
zastosowanie komputera do 
najbardziej niewdzięcznej pracy. 
Zatem spróbujmy zmusić kompu¬ 
ter, by sprawdzi za nas czy nasz 
program zawsze zatrzyma się. Nie¬ 
stety spotka nas tu niemiła niespo¬ 
dzianka. Da się bowiem udowod¬ 
nić, że nie można napisać progra¬ 
mu sprawdzającego czy inny pro¬ 
gram zatrzymuje się dla wszystkich 
danych. Postaram się udowodnić 
to stwierdzenie. 

Załóżmy, że udało się nam napi¬ 
sać procedurę W, której daną wej¬ 
ściową jest tekst źródłowy jakiegoś 
programu, a na wyjściu otrzymuje¬ 
my wartość PRAWDA, jeżeli dany 
program zawsze będzie kończył 
obliczenia i FAŁSZ w przeciwnym 
przypadku. Napiszmy teraz nastę¬ 
pujący program: 


program akuku; 
begin 

if W(tekst źródłowy programu 
akuloi) then while true do; 
end. 

Teraz wystarczy uruchomić naszą 
procedurę W z programem akuku 
jako daną wejściową. Jeżeli wyni¬ 
kiem działania W będzie PRAW¬ 
DA, to powinno to oznaczać, że 
program akuku zatrzyma się. Jest 
jednak inaczej, co widać na wydru¬ 
ku: jeżeli W(tekst źródłowy pro¬ 
gramu akuku) jest prawdą, to wpa¬ 
damy w nieskończoną pętlę. 

Jeżeli procedura W da wynik 
FAŁSZ, to pętla nie będzie wykony¬ 
wana i program zakończy oblicze¬ 
nia, znów wbrew wskazaniu proce¬ 
dury W. Widać zatem, że nie może 
istnieć uniwersalna procedura W 
testująca własność stopu progra¬ 
mów komputerowych. 

LR 


JAK LICZYC 

Komputer został wymyślony jako 
maszyna do liczenia. Zajmijmy się 
więc na przykład problemem obli¬ 
czania pierwiastków kwadrato¬ 
wych z danych liczb. 

Na pewno każdy Czytelnik KMK 
wie, że w Pascalu, którym posługu¬ 
jemy się na naszej stronie jest funk¬ 
cja standardowa SORT, podająca 
gotowy wynik, taki, by: SORT(x)* 
SORT(x)=x. Ja jednak proponuję 
spróbować samemu napisać funk¬ 
cję obliczającą pierwiastek kwad¬ 
ratowy z liczby podanej jako dana 
wejściowa. Wyważanie otwartych 
drzwi może być bardzo pouczają- 




Przedstawię dwa sposoby obli- 
czarua pierwiastków metodą itera- 
cyjną. Pierwszy można nazwać me¬ 
todą artyleryjską. Polega on na 
strzelaniu pewnymi liczbami coraz 
bliżej celu. Za każdym razem, gdy 
nasz strzał chybia poprawiamy ce¬ 
lownik. Oczywiście robimy to "mą¬ 
drze". To znaczy, gdy mieliśmy za 
małą liczbę dodajemy do niej okre¬ 
śloną wartość. Dalej, gdy przesko¬ 
czymy cel, to wartość skalującą 
zmniejszamy o połowę i odejmuje¬ 
my od hipotetycznego wyniku. 
Gdy znów miniemy cel, to ponow¬ 
nie zmniejszamy wartość skalującą 
o połowę i zaczynamy ją dodawać. 
Postępujemy tak do chwili uzyska¬ 
nia wymaganej dokładności. Oto 
program realizujący ten algorytm: 
program armata; 
const blad=0.00001; 
var liczba,a,b:real; 
begin 

writeCPodaj liczbę:’); 
readln(liczba); 
a:=l; 
b: = 0.5; 

while abs(b)>blad do 
begin 

ifa *a<=liczba then 
while a*a<liczba do 
a: = a+b 
else 

while a*a>liczba do a:=a-b; 
b:=b/2; 
end; 

writeln(liczba,’=’,a,’*’,a); 
end. 

Drugi sposób jest bardziej subte¬ 
lny. Najpierw wybieramy dowolnie 
dwie liczby, których iloczyn daje 
daną liczbę (tę, której pierwiastek 


liczymy). Jeżeli wybrane liczby są 
ró^me (lub różnią się o mniej niż za 
dana dokładność), to już mamy ko¬ 
niec obliczeń. Jeżeli jednak wybra¬ 
ne czynniki są dość odległe od sie¬ 
bie, to musimy je zmodyfikować. 
Jednemu przypiszemy wartość bę¬ 
dącą średnią arytmetyczną obu 
wybranych liczb. Drugiemu - iloraz 
z dzielenia liczby danej przez zmo¬ 
dyfikowany pierwszy czynnik. W 
ten sposób znów mamy dwie licz¬ 
by, których iloczyn jest daną licz¬ 
bą, a więc możemy przypuszczać, 
że te liczby są szukanymi pierwias¬ 
tkami. Jeżeli dokładność jest dalej 
za mała, to powtarzamy modyfikac¬ 
je tak długo jak trzeba. Oto pro¬ 
gram realizujący ten algorytm: 


program średni; 


const blad=0.00001; 
var liczba,a,b:real; 


begin 

write(’Podaj liczbę: ’); 
readln(liczba); 
a:=liczba; 
b: = l; 

while abs(a-b)>blad do 
begin 

a:=(a+b)/2; 
b:=liczba/a; 
end; 

writeln(liczba,’=’,a,’ * ’,b); 
end. 

Teraz należy powiedzieć, który z 
programów jest "lepszy": oba reali¬ 
zują tę samą funkcję, oba są dość 
krótkie. Szukając odpowiedzi na to 
pytanie zmierzyłem czas Dotrz 0 briv 

^sZłaGiTiU £, lycn programów do 
obliczenia pierwiastka z pewnej li¬ 
czby. Konkurencję wygrał pro¬ 
gram średni. Był szybszy o około 22 
procent od programu armata. Nie 
znaczy to jednak, że prograun ar¬ 
mata jest bezużyteczny. Można go 
łatwo przerobić tak, by liczył pier¬ 
wiastki dowolnego (całkowitego) 
stopnia. Takiej przeróbki nie wy¬ 
trzyma program średni. 

LR 


REGUŁA 

MARTWEGO 

PRZEDMIOTU 


Każdy przedmiot, niezależnie od 
położenia, konfiguracji, budowy i 
przeznaczenia, może w dowolnej 
chwili zadziałać w zupełnie nieo¬ 
czekiwany sposób, z przyczyn, któ¬ 
re są albo całkowicie niejasne, 
albo zupełnie tajemnicze. 
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Drodzy Czytelnicy! 

"Forum” to rubryka przeznaczona w całości do Waszej dyspozycji. 
Możecie do niej pisać nie tylko o swoich osiągnięciach, nadsyłać uży¬ 
teczne programiki czy "sztuczki i chwyty”, które odkryliście, ale mo¬ 
żecie pisać także o problemach, które spotykacie w pracy z mikro¬ 
komputerami. Być może ktoś inny je rozwiązał i będzie mógł Wam tą 
drogą pomóc. 

Jeżeli przedmiotem korespondencji jest program, prosimy Was o 
załączanie (w miarę możliwości) dwóch jak najbardziej kontrastowo 
(tzn. czarno na białym) przygotowanych wydruków programu. Gdy 
program jest napisany w języku asemblera i autor podaje listę odpo¬ 
wiednich POKERÓW, dobrze jest zaopatrzyć je w sumę kontrolną, któ¬ 
ra ułatwi potem innym uruchomienie programu. 

Poza tym mamy jeszcze następujące prośby: o zwięzłe formułowa¬ 
nie listów, o umieszczanie na kopertach dopisku "Forum” oraz poda¬ 
wanie wewnątrz listu dokładnego adresu nadawcy. Za publikowane 
w tej rubryce programy i ciekawe "sztuczki i chwyty” przysługuje ho¬ 
norarium, zgodne z obowiązującymi u nas stawkami. Dla przypom¬ 
nienia podajemy nasz adres: 

PMI "Komputer” 
ul. Koszykowa 6a 
00-564 Warszawa 
"Forum” 

Dzisiaj prezentujemy: dalszy ciąg spectrumowskiego us¬ 
prawnienia edytora systemowego oraz, także dla ZX Spectrum, znacznik 
współrzędnych. 

Zapraszamy! 


Usprawnienie edytora - ciąg 
dalszy (ZX Spectrum) 

Szanowna Redakcjo! 

Przesyłam drugi program uspra- 
wnieniający edytor ZX Spectrum. 
Umożliwia on przesuwanie kursora 
w górę i w dół w obrębie edytowa¬ 
nego wiersza. 

Aby używać programu razem z 


US.EDYTORA z "Komputera” nr 6/ 

88 należy: 

• przepisać program nr 1 i zapi¬ 
sać na taśmie zleceniem SAVE 
"nazwa” LINĘ 10. 

• za programem nr 1 zapisać blok 
zawierający kod US.EDYTORA 
(z nr 6/88), 

• przepisać i uruchomić program 
nr 2 i po poprawieniu ewentual- 


prdgram nr 1 

1 REM DOLt^ZANIE PROGRAMJ "US.EDYTORA" 

10 CLEAP 647Ć3: LOAD "US.EDYTDRA"CODE : LOAD "FRZEB. h"CODĘ 
20 POI E cj 5418,205: POPE 65419.252: PDPE 65420,252: POPE 65468, 
40: POt E 65469.35: POł E 64844,201 

30 PANDOMIZE U3R 65511: POfE 23755.128: STOP 

program nr 2 


10 REM PRZESUWANIE \ URSORA 

2 ;• REM 

30 REM RYSZARD JAR2A, 1988 

40 REM 


50 Cl-EAR 65244: LET S=0: FOR 1=65414 TO 65535: RE AD X: 
+ X: POPE I.X: NEXT I 


LET S=S 




6C> IF S 
70 SAVE 
80 DATA 
90 DATA 
lO«i DATA 
110 DATA 
120 DATA 
130 DATA 
140 DATA 
150 DATA 
160 DATA 

170 data 


>14296 THEN PRINT "POPRAW DANE '": STOP 
"PRZES.ł "CODĘ 65414,122 


245,229, 

197,213. 0, 0. 

0. 

42. 61. 

92. 

94, _'5. Sto 

33.127. 

16.167,237. 82. 

124. 

181. 32, 

26. 

42. 91, 92 

6, 3.2. 

62, 254,219.254, 

31. 

56, 14. 

62. 

127,219.254 

31, 48. 

21, 62. 191.219. 

254, 

31. 48. 

23. 

58.127.253 

254,255. 

0, 0 .209.193, 


241,195. 

56, 

0. 197,205 

12, 16, 

193. 16.249. 24, 

7, 

197,205. 

7. 

16.193. 16 

249,205, 

29. 17,243, 1. 

-T 

78, 11. 

120. 

177. 32,251 

20°,193, 

225.241.251.201, 

62. 

59,237, 

71 . 

237. 94. 33 

221,254, 

34,123, 92,201, 

195, 

134,255. 

237, 

86,201, O 

0. 0, 

0, 0, 24 






nych błędów zapisać utworzony 
kod maszynowy na taśmie, 

• całość ładować i uruchamiać 
przez LOAD” ”. 

Program nr 1 samoczynnie kasu¬ 
je się po wykonaniu zadania. Aby 
używać programu jedynie do prze¬ 
suwania kursora należy postąpić 
jak w p.3. Uruchamianie następuje 

— 


— 

wtedy przez: CLEAR 65244: LOAD 
”PRZES.K”CODE: RANDOMIZE 

USR 65511. Kursor przesuwa się 
klawiszami CAPS SHIFT + ENTER 
i CAPS SHIFT + SPACE. Program 
można wyłączyć przez RANDOMI¬ 
ZE USR 65527. 

Łączę pozdrowienia 

Ryszard Jarża 
Częstochowa 



1 

« 


PRZESUWAI 


10 

*D+ 




20 

*c- 



24 

30 

K0D_JR 

EOU 

24 

23643 

40 

k:_cur 

EGU 

23643 

23675 

50 

UDG 

EGU 

23675 

23613 

60 

err_sp 

EGU 

23613 


65 




4108 

70 

right 

EGU 

#100C 

4103 

80 

LEFT 

EGU 

#1007 

4381 

90 

E_CQPY 

EGU 

#1 1 ID 

64895 

100 

FLAG 

EGU 

64895 


105 

; NoMa 1 

procedura obsług 

65414 

1 lO 


ORG 

65414 

65414 

120 

PRZERW 

PUSH 

AF 

65415 

130 


PUSH 

HL 

65416 

140 


PUSH 

BC 

65417 

150 


PUSH 

DE 

65418 

160 


DEFB 

0,0,0 

65421 

170 


LD 

HL.(ERR_SP 

65424 

180 


LD 

E,(HL) 

65425 

190 


INC 

HL 

65426 

200 


LD 

D,(HL) 

65427 

210 


LD 

HL.#107F 

65430 

220 


AND 

A 

65431 

230 


SBC 

HL, DE 

65433 

240 


LD 

A.H 

65434 

250 


OR 

L 

65435 

260 


JR 

NZ,KONIEC 

65437 

270 


LD 

HL,(K_CUR) 

65440 

280 


LD 

B, 32 

65442 

290 


LD 

A,#FE 

65444 

300 


IN 

A,(#FE) 

65446 

310 


RRA 


65447 

320 


JR 

C,KONIEC 

65449 

330 


LD 

A,#7F 

65451 

340 


IN 

A,(#FE) 

65453 

350 


RRA 


65454 

360 


JR 

NC,DOL 

ó545to 

370 


• 

%^U 

^ MPP 

65458 

380 


IN 

A,(#FE) 

65460 

390 


RRA 


65461 

400 


JR 

NC,GÓRA 


405 

:Zakończenie obsługi p 

65463 

410 

1 ONIEC 

LD 

A,(FLAG) 

65466 

420 


CP 

#FF 

65468 

430 


DEFB 

0, 0 

65470 

440 


ROP 

DE 

65471 

450 


POP 

BC 

65472 

460 


POP 

HL 

65473 

470 


POP 

AF 

65474 

480 


JP 



485 

iPrzesuwanie kursora w 

65477 

490 

DDL 

PUSH 

BC 

65478 

500 


CALL 

RIGHT 

65481 

510 


POP 

BC 

65482 

520 


DJNZ 

DDL 

65484 

530 


JR 

k DPIUJ 


535 

;Przesuwanie ^ ursora w 

65486 

540 

GÓRA 

PUSH 

BC 

65487 

550 


CALL 

LEFT 

65490 

560 


POP 

BC 

65491 

570 


DJNZ 

GÓRA 


575 

:Wyświetlanie edytowani 

65493 

580 

KOPIUJ 

CALL 

E_C0PY 

65496 

590 


DI 


ĄO-T 

W • / « 



LD 

BC,20000 

65500 

610 

CZEKAJ 

DEC 

BC 

65501 

620 


LD 

A, B 

65502 

630 


□R 

C 

65503 

640 


JR 

NZ.CZEKAJ 

65505 

650 

N_R0M 

POP 

DE 

65506 

660 


POP 

BC 

65507 

670 


POP 

HL 

65508 

680 


POP 

AF 

65509 

690 


El 


65510 

700 


RET 



705 

;Procedura instalująca 

6551 1 

710 

INSTAL 

LD 

A, 59 

65513 

720 


LD 

I.A 

65515 

730 


IM 


65517 

740 


LD 

HL,65245 

65520 

750 


LD 

(UDG).HL 

65523 

760 


RET 



765 

;Ok do właściwej proi 

65524 

770 


JP 

PRZERW 


775 

;Wyłąc 

zani e 

programu- 

65527 

780 

KASUJ 

IM 

1 

65529 

790 


RET 



795 

• 

m 



65530 

800 


DEFS 

5 


805 

:kod tworzący z bajtem 

65535 

810 


DEFB 

KOD JR 


lE KURSORA 


;Kod instrukcji JR. 

;Zmienna zawierająca adr. kurs- 
;Zmienna zawierająca adres UDG- 
;Zawiera adr, na stosie,gdzie 
;parniętany jest adr.obsi.błędu- 
;Przesuwanie kursora w prawo. 

;Przasuwanie kursora w lewo. 

;D^u^ owanie edytowanego wiersza 
; Zmienna programu '•US. EDYTORA"- 
przerwani a. 

;Przechowaj rejestry- 


:Miejsce na CALL 64764. 

;Znajdź adres procedury obsłu- 
;gi błędu i wpisz go do DE.Je— 
;żel 1 pracuje edytor,to adres 
;ten powinien wynosić #107F. 

;Zerowanie CY. 

;Czy pracuje edytor (HL=DE>'^ 


;Nie-zakortcz obs.przerwani a. 

;Do HL adres kursora- 
;Do B liczba przesunięć kurs- 
; Odczytaj z portu ♦*FEFE,czy 
;naciśnięto CAPS SHIFT. 

;Nie—zakoPcz obs.przerwania. 
;0dczvtaj z portu łł7FFE,czv 
;naciśnięto SPACE. 

;Tak—przesuwaj łursor w dćł- 
cOdczytaj z portu łłBFFE,C 2 y 
;naciśnięto tN TER. 

;Tak—przesuwaj kursor w gCrę. 
zerwani a. 

;Czy US.EDYTORA zezwala na pow- 
;rćt przez ROM*^ Nie—skocz w 
;przód-Miejsce na JR Z,N_ROM. 

;Odtwórz rejestry. 


;Sl^ocz do obs. przerw, w ROM. 
dół (32 pozycje w prawo). 

;Przechowa j 1 icznił przesunięć. 
;PrzesuP kursor w prawo. 
;0dtwórz licznik. 

;Powtarzaj 32 razy. 

:5kopiuj wiersz na elran. 
górę (32 pozycje w lewo). 

;Przechowaj licznik przesunięć. 
;PrzesuP kursor w lewo. 

;Odtwórz licznik. 

;Powtarzaj 32 razy- 
go wiersra i koniec obs-przerw. 
; Uivświ et 1 edvtowanv wi ersz - 
;Przerwani a musz ą być zablok o- 
• wane • 

;Opóźnienie. 


;Odtwórz rejestry. 


;Włącz przerwania i wróć nie 
;uruchamiając procedury z ROM. 

;Ulpisz do rejestru I nr stroni- 
;cv wek torów( niewykorz. obszar 
;ROM).Włącz 2 tryb przerwaó. 
;Zmieh adres UDG. 

;Wróć do BASIC-a. 

edury obsługi przerwania. 


;5 wolnvch łomóre^. 
z ROM-u(adres O) rozkaz JR -13, 
;tj. skok pod adres 65524, 



o comPUćE? 
































Input-output 


Znacznik XY (Zx Spectrum) 



Znacznik !i;V. 

Zet CAD Spectrin lit 

Prezentowany proyraii rysuje na ebanie 
wnitora widoczny niezależnie od treści 
obrazu bezkolizyjny znacznik współrzęd¬ 
nych x,v - według nastepujećego algorytm: 

- analiza wzoru znacznika w odniesie¬ 
niu do współrzędnych i dla nanoszonych 
punktów zapisanie adresu, bitu w adreso¬ 
wanej koMÓrce i treści obrazu; 

- narysowanie znacznika (w wyznaczo¬ 
nych punktachi w relacji odwrotnej do 
treści obrazu; 

- blokada czasowa program; 

- odtworzenie poprzedniej treści obra¬ 
zu; 

- blokada cz^ program. 

Sposób Oprowadzenia program do pawie* 
ci pozostawiali inwencji zainteresowanych 
prograMistów. 


5987^221LD 

59920-285 aU, 

876- 42 

IX, 

921- 85 nn 

877- 28 (nn) 

92^234 SMS 

878-233 im 

923-235 £XDE,tl 

879-253 ID 

924-119 LD(ID,fl 

888- 42 

IV, 

925- 44 IHCL 

881- 26 (nn) 

926- 26 LDfl,(DO 

882-233 sse74 

927-119 ID(1D,R 

883-281 RET 

928- 44 IHCL 

884-160- 

U 

929-115 LD(1D,E 

885- 64 

0 

N 

938- 44 IHCL 

886-160- 

1 T 

3 

931-114 LD()i),D 

887- 0- 

* 

93^44IHCL 

888- 0 

0^ 

3^ 

933-289 POPDE 

889- 0 

05 

934-241 POPflf 

890- 0 

H N 
•hO 

935-221 IHC 

891- 0 

31 

936- 35 IX 

89^ 0 

oc 

937- 16 D3HZ, 

893- 0-1 


938-231 esssM 

894- 33 lDtŁ, 

939-221 POP 

895-234 nn 

940-225 IX 

896-255 (54U 

941-253 IHC 

897-285 CflU., 

94^35 IV 

898-227 im 

943- 27 DEC DE 

899-233 


' 944- 13 DECC 

908-221 DEC 

945- 32 3RHZ, 

901-43 

IX 

946-218 esssM 

90^253 DEC 

947- 33 IDU, 

983- 43 

IV 

948-234 nn 


59965-2W 

966- 7fi 

967- 234 

968- 6 

969- 5 

970- 45 

971- 86 
97M5 

973- 94 

974- 45 

975- 126 

976- 18 

977- 45 

978- 16 

979- 246 
988- 1 
981-255 
98^50 

983- 11 

984- 128 

985- 177 

986- 32 

987- 251 

988- 281 

989- 213 

990- 197 

991- 253 
99^229 

993- 225 

994- 175 


CfU, 

nn 

sam 

LDB, 

n 

D£CL 

IJ)D,(łD 

DECL 

LDŁUD 

DECL 

LDHOD 

LD([0,fl 

DECL 

D3HZ, 

i im 

LD8C, 

nn 

DECBC 

LD8,B 

ORC 

3RNZ, 

i im 

RET 

PUSHDE 

PUSHBC 

PUSH 

IV 

POPU 

iiORfl 


59995- 17 

996- 176 

997- 0 

998- 237 

999- 82 
60080- 48 

001 - 1 
00^25 
083-221 
004-229 
085-193 
086- 62 
007-175 
088-149 

OOiCLJHK 

w!r«D 

018-176 
011- 34 
01^2e5 
013-114 
014-234 
015-193 
016-289 
017-281 
018- 71 
019-62 
020-128 
821- 15 
02^ 16 
023-253 
024-281 


LDDE, 

nn 

SBCłl, 

C€ 

3RNC, 

ttm 

RDOftDE 

PUSH 

IX 

POPBC 

LDR, 

n 

SUBL 

Cdi, 

nn 


C«i, 

nn 

(MU 

POPBC 

POPDE 

RET 

U)B,R 

LDR, 

n 

RRCR 

D3HZ, 

esMZi 

RET 


904- 17 IJ)DE, 

985- 238 im 

986- 233 sam 

907- 14 LDC, 

908- 3 n 
989-221 PUSH 

910- 229 IX 

911- 61J)B, 
91^ 3n 

913- 26 lJ)fl,fl)e 

914- 7RLCfl 

915- 48 3RHC, 

916- 18 esaaas 

917- 245 PUSHRF 

918- 213 PUSHDE 

919- 235 EXDE,tŁ 


949-255 
958- 6 
951- 5 
S5M26 

953- 44 

954- 44 

955- 94 

956- 44 

957- 86 

958- 44 

959- 235 

960- 174 

961- 119 
96^235 

963- 16 

964- 243 


(SSU 

LDB, 

n 

LDR,IHU 

IHCL 

IHCL 

tJ)E,lll) 

IHCL 

tJ)D,0L) 

IHCL 

EXDE,ii 

X0R(łU 

U)IIL),fl 

EXDE,łL 

D3HZ, 

esaasz 


Dla jednoznacznej orientacji trzycy¬ 
frowa koócówka adresu oznaczać bedzie po¬ 
czątek kouentowanej procedury ewentualnie 
odnośnik. 

Po RRHDOHIZE USR 59894 lub 205,246,233 
rejestry IX i IV ładowane sa wartościam 
współrzędnych x,y (897) co oznacza, że 
kowórki 59676^7 przechowują x a kowórki 
59674^5 y. Hzór znacznika analizowany 
jest od lewego dolnego rogu 1886) w kwa¬ 
dracie 3s3 1987)} (911) a po znalezieniu 
każdej T (914) liczony jest adres pur 
ktu (920) wykorzystując fra^ient ciekawej 
procedury z ROH-u (089) i zapisany zosta¬ 
je bit w adresie, gdyż bajt to 8 punktów 
po X (924), treść obrazu (926) i dwubaj¬ 
towy adres dla ekranu (929). Teraz ryso¬ 
wany jest znacznik (947) jako odwrotność 
treki obrazu (968). Dla zatrzymnia zna¬ 
cznika przez Kwnt na ekranie procesor 
dostaje zadanie: ‘kolejno odlicz' (965), 
prograw jest czasowo blokowany a następ¬ 
nie przywrócona zostaje poprzednia treść 
obrazu (968) i dla symtrii procesor po¬ 
nownie odlicza (988). 

Dociekłimich prograRistów pragnę uspo¬ 
koić, że dwubajtowa obsługa x,y (875,991) 
oraz popisanie po znakach UDS (894) nie 
sa niedokładnością programwa. 

Prograu w któnn nyszkuje prezentowany 
znacznik dopuszcza współrzędne x,y odpo¬ 
wiednio: 1 t510,1t 3S0 oraz posiada własny 
pełnoiMiiarowy zestaw znaków (17255). 

]ai Gawęda 
Idarszawa 


X128 V 87 

Zet CAD Spectiu 7 3/ 


Przedstawiona poniżej procedura wpi 
je ciąg znaków na ekran mnitora. Hiiiaga 
załadowania do pary rejestrów BC adresu 
początku ciągu kodów RSCII, znaków do wpi¬ 
sania - zakoliczonego zerew oraz załadowa¬ 
nia do pary rejestrów DE, adresu panieci 
ekranu - niejsca wpisu, w7g obowiązującej 
dla SpectruR organizacji. 


59808- 18 

LDR,(BC) 

59824- ILDBC, 

809-167 

RH)R 

825- 8 nn 

810-288 

RETZ 

826- 60 iSMo 

811- 3 

1HC8C 

827- 9 RDDfl,BC 

81^285 

CRli, 

828-213 PUSHDE 

813-169 

nn 

829- 6 LDB, 

814-233 

SM17 

830- 8 n 

815-24 

3R, 

831-126IDR, m 

816-247 

eSNN 

832- 18LD(De,R 

817-197 

PUSHBC 

833- 35 IHCIi 

818-38 

LDH, 

834- 2BIHCD 

819- 0 

n 

835- 16 D3HZ, 

820-111 

LDL,R 

836-258 essHi 

821-41 

RDDH.,HL 

837-219 POPDE 

82^41 

l»Dll,HL 

838-193 POPBC 

823- 41 

RDOfl,HL 

839- 19 IHCDE 



840-211 RET 


Do akumlatora ładowany jest kod (888) 
1 jeżeli nie jest to *0' - wywoływany jest 
pockirograH wpisu pojedynczego znaku (812). 
Ponieważ kod RSCII oznacza kolejny numr 
8-iiiu bajtów wzorca znaku liczony od po¬ 
czątku zbioru wzorców /generatora znaków/ 
- kod poMiożony przez 8 (818) i dodany do 
początku adresu generatora znaków (8^), 
jest adteseH skąd 8 bajtów zostanie prze¬ 
pisanych do panieci ekranu (829). 

Praktyczne m^iorzystanie tej procedury 
do wpisu współrzędnych x,g niezwykle przy¬ 
datnych do pracy twórczej na ekranie k- 
nitora przedstawia prezentowany progran. 



60025- 88 T 

60048-234 SM* 

826- 49 r 

049- 38 IDE, 

027- 50 r 

850-128 n 

028- 56 ‘8' 

051- 42 IDU, 

029- 32 “ 

05^ 26 (nn) 

830- 32 “ 

053-233 s*7S 

831- 89 r 

054-295 CRLL, 

03^32 “ 

055-162 im 

833- 56 ‘8' 

056-234 SMss 

834- 55 T 

857- ILDBC, 

835- 0 

858-121 nn 

036-175 XORR 

85^234 ms 

037- 50 LD 

060- 17 LDDE, 

838- 28 (nn) ,R 

861-192 nn 

839-233 ssctó 

06^ 88 2*72 

040- 17 IDDE, 

063-195 3P, 

041-122 nn 

064-160 im 

04^234 (Mzc 

065-233 

043- 42 LDHL, 

066- ILDBC, 

044- 28 nn 

067-100 im 

045-233 5*71 

068- 0 

046-285 CflL, 

069-175 X(]fiR 

047-162 nn 

070-237 S8CIŁ, 


60071- 66 
07^6I 
873- 48 
074-251 

875- 198 

876- 47 
077-254 

878- 48 

879- 32 

880- 2 
081-62 
08^32 
083- 18 
084- 28 
085-183 
086-125 
087-129 
088 6 
889-255 
090- 4 
891-214 
09^ 10 


K 

INCR 

3RHC, 

esN» 

RDDR, 

n 

CP 

n 

3RNZ, 

ttm 

LDR, 

n 

U)(DD,R 

INCE 

li)H,R 

li)R,L 

flDDR,C 

LDB, 

n 

IHCB 

SUB 


n 


60893- 48 
094-251 
095- 79 
096-128 
097-167 
098- 32 
099- 5 
100-62 
101- 32 
10M88 

103- 48 

104- 3 

185- 62 

186- 48 

187- 128 
108- 18 
189-28 
118-62 
111- 58 
11M29 

113- 18 

114- 281 


3RNC, 

eaaoM 

U)C,R 

LDR,B 

flIDR 

3RHZ, 

eatiK 

LDR, 

n 

CPH 

3R2, 

eatiM 

IDR, 

n 

RDDR,B 

LD(DB,R 

IHCE 

U)R, 

n 

RDDR,C 

LD(De,R 

RET 


Początek program (836) stanowi zwrot- 
;a wi^aczajaca zbędny wpis współrzędnych 
/na tyn etapie przedsięwzięcie na wyrost/. 

Hartość współrzędnej x przechowywana w 
koRórkach 59676 i 7 po załadowaniu io paty 
iestrów H (043) poddana zostaje roz¬ 
dzieleniu (046) na setki (078), dziesiątki 
(091) i reszte. Wynik każdej operacji za- 
Mieniany jest na kod RSCII przy czyM dla 
pierwszych zer na pozycjach setek i dzie¬ 
siątek przydzielana jest spacja a wynik 
wpisywany do konórek 60826,7 i8 (040). I- 
dentycznej obróbce poddana zostaje współ- 
dna y (051) przechowywana w konórkach 
59674 i 5 a wynik wpisany do konórek 68832 
,3i 4 (049)..Zliodernizowany ciąg kodów, 
którego adres ładowany jest do rejestrów BC 
(05^, jako współrzędne X V, wpisany zos¬ 
tanie na ekran (063) w piejscu określonyw 
para rejestrów DE (060) - dla tego adresu 
lewy, górny róg okna systemwego. 

3est to bardzo wygo^ sposób wpisywa¬ 
nia znaków na ekran, ale nie jedyny. 

Han nadzieje, że wielu czytelników w 
ty* prograuie /i poprzednich^ z C!*lu ‘Zet 
CRD Spectrup’ znajdzie coś dla siebie. 
Eksperci sa poza konkurencja, pniej zaa¬ 
wansowani poga sprawdzić swoje pożliwości 
i pi^awić a początkujących poge zapewnić, 
że jeżeli nie strącą cierpliwości /razep 
z Redakcja - niestety nie upiep korzystać 
z asenblera/ to już niedługo beda pisać, 
rysować, projektować na ekranie, poza e- 
kranep, schepaty, płytki drukowane, tekst 
w poprzek i do góry nogapi ignorując zu¬ 
pełnie obowiązującą dla Spectrup organi¬ 
zacje papieci ekranu. Hymgać to b^ie 
zgropadzenia wielu procedur nie zawsze sa- 
podzielnych, no ale początki wszei&ie sa 
trudne. Proponuje zatep /zainter^ium/ 
jako zadanie dopowe progranowa zpiane x ,9 
w połączeniu ze znacznikiep (Zet CRD Spec¬ 
trup /2/) i przypiarke do poła operacyj¬ 
nego dla Spectrup - 512 * 352 punkty. 

3ap Gawęda 
Marszawa 
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Wydarzeniem ostatnich miesięcy na rynku profesjonalnego 
oprogramowania mikrokomputerów było pojawienie się kolejnej 
wersji sztandarowego produktu firmy Ashton-Tate-Tpakietu zarzą¬ 
dzania relacyjnymi bazami danych - dBase IV wersja 1.0. Fakt ten 
poprzedziły, pi±>likowane w fachowej prasie, liczne spekulacje, 
krytycznie odnoszące się do potencjalnych możliwości oczekiwa¬ 
nego następcy dBase III Plus. Autorzy oceniając wysoko funkcjo¬ 
nalność dBase III Plus, swój sceptycyzm opierali na poniekąd słu¬ 
sznym założeniu, że pakiet, który wniósłby nową jakość w syste¬ 
mach zarządzania bazami danych, musiałby być tak duży i skompli¬ 
kowany, że jego przydatność dla przeciętnego użytkownika stała¬ 
by się niewielka. Sceptycyzm ten uzasadniała dodatkowo znana fi¬ 


lozofia producenta, polegająca na dążeniu do wyposażania każdej 
następnej wersji systemu w szereg nowych możliwości, co nieu¬ 
chronnie prowadziło do wzrostu jej rozmiarów. Na szczęście oka¬ 
zało się, że prognozy te nie znalazły potwierdzenia w rzeczywistoś¬ 
ci. Funkcjonalność dBase IV, łatwość jego użycia i prostota obsługi 
skłaniają do oceny, iż jest to w chwili obecnej najlepszy, dostępny 
na rynku system zarządzania bazą danych. 

Firma Ashton-Tate wprowadziła na rynek jednocześnie dwie 
wersje dBase rv - standardową, dedykowaną przeciętnemu użyt¬ 
kownikowi i wersję rozszerzoną - dBase IV Developer’s Edition - 
przeznaczoną dla programistów tworzących profesjonalne aplika¬ 
cje stosowane w obszarach zarządzania bazami danych. 

Użytkownika dBase III Plus w pierwszym zetknięciu z nową we¬ 
rsją zaskoczy zapewne jej wielkość. Standardowa wersja dBase IV 
dostarczana jest na 14 dyskietkach 360 KB, natomiast wersja dBase 
rv Developer’s Edition zajmuje aż 17 dyskietek. Pomimo tej wiel¬ 
kości, instalacja programu jest bardzo prosta. Wykonuje ją dostar¬ 
czony z pakietem program instalacyjny (INSTALL.BAT). Umożliwia 
on użytkownikowi zdefiniowanie konfiguracji komputera, na któ¬ 
rym będzie eksploatowany dBase IV, w tym maksymalnie czte¬ 
rech drukarek, wyspecyfikowanie kart grafiki, nawet tych, które 
używają 43-liniowego trybu wyświetlania informacji oraz zmodyfi¬ 
kowanie zawartości plików AIJTOEXEC.BAT i CONFIG.SYS. 

Na wstępie kilka słów o wymaganiach sprzętowych. dBase IV 
może być uruchomiony na komputerach w pełni z systemem IBM 
PC, wyposażonych w dysk twardy i minimum 640 KB pamięci RAM, 
pracujących pod kontrolą systemu operacyjnego DOS 3.1 (lub pó¬ 
źniejszego). Jeżeli komputer wyposażony jest w dodatkowe bloki 
pamięci o adresach powyżej 640 KB i 1 MB, dBase rv automatycz- 
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nie wykorzystuje je, używając w tym celu standardowej procedury 
VDISK. 

Choć filozofię budowy dBase IV oparto w znacznej mierze na 
wersji pakietu dBase III Plus, to stanowi on jakościowo nowy sy¬ 
stem zarządzania bazą danych. Wiele opcji dBase IV nie ma w ogó¬ 
le odpowiedników w wersji dBase III Plus lub ma znacznie rozsze¬ 
rzone funkcje. Spośród najważniejszych należałoby wymienić: 

• jakościowo nowy sposób komunikowania się z użytkownikiem; 

• implementacja standardowych relacyjnych języków zapytań: 
Query-by-Exainp}e i SOL (Structured Oueiy Language); 

• generator aplikacji, będący prostym w użyciu narzędziem słu¬ 
żącym do tworzenia programów aplikacyjnych, bez konieczno¬ 
ści napisania chociażby jednej linii kodu programu; 

• wbudowany kompilator, debugger i linker; 

• możliwość definiowania przez użytkownika własnych funkcji; 

• możliwość używania z bazą danych praktycznie nieograniczo¬ 
nej liczby indeksów; 



# możliwość pracy w systemie okien definiowanych przez użyt¬ 
kownika. 

Wprowadzony w dBase rv, zupełnie nowy, sposób komunikacji 
z użytkownikiem umożliwia wykorzystanie jego możliwości bez 
konieczności pracy w trybie interpretacyjnym (dot prompt). 

Każda z pełnoekranowych komend dBase rv, począwszy od 
APPEND a skończywszy na SET, została wyposażona, dla ułatwie¬ 
nia jej użycia, w rozwijane menu. Liczbę dostępnych w nich opcji 
można zwiększyć poprzez zdefiniowanie makrosekwencji klawi¬ 
szy, realizujących dodatkowe, potrzebne użytkownikowi funkcje. 

Narzędzia do projektowania wzorów formularzy, etykietek adre¬ 
sowych i raportów, wykonane zostały w oparciu o zasadę WYSI¬ 
WYG (What You See Is What You Cet), gwarantującą całkowitą 
identyczność dokumentu drukowanego z zaprojektowanym. Zna¬ 
cznie poprawiono system zarządzania katalogami dBase. 

W dBase lY połączone zostały formaty ekranowe komend BRO- 
WSE i EDIT, z których utworzony zosti jeden format, składający 
się z dwóch części. Klawiszem F2 wybierać można pomiędzy wy¬ 
świetlaniem danych w postaci charakterystycznej dla komendy 
BROWSE lt±i w postaci formularza, wykorzystywanego w komen¬ 
dzie EDIT. Dopuszczalna wielkość bloków tekstu przechowywa¬ 
nych w polach typu MEMO została zwiększona z 4 KB do 64 KB. Do 
ich edycji, która w dBase III Plus przyprawiała programistę o 
przysłowiowy ”ból głowy”, wprowadzono wysoce funkcjonalny 
edytor, zawierający m.in. opcje wyszukiwania fragmentów tekstu 
(search). Ponadto ich zawartość może być" argumentem każdej 
funkcji operującej na łańcuchach znaków (LEFT(), RIGHT(), 
SUBSTRO, itp.). Sterowanie ruchem kursora w ekranach edycji ko¬ 
mend BROWSE i EDIT charakteryzuje się większą logiką i jest ła¬ 
twiejsze. 

Znacznie rozszerzone zostały możliwości tworzenia formatów 
ekranowych dla wprowadzanych i wyprowadzanych informacji. 
Projektowanym elementom formularzy można przypisywać różne 
kolory, wyróżniając je graficznie od innych elementów za pomocą 
ramek lub specyficznych linii. Ponadto istnieje możliwość kopio¬ 
wania tekstów, pól i okien z jednego miejsca formularza w inne. Do 
projektowanego formularza można wprowadzać pola, których za¬ 


wartość jest obliczana (pola obliczeniowe). Użytkownik ma do wy¬ 
boru większą liczbę funkcji i znaków formatujących. Pola typu 
MEMO mogą być redagowane we wcześniej przygotowanych ok¬ 
nach. Użytkownik może również określić pola, które będą edyto¬ 
wane jedynie wtedy, gdy spełniony zostanie określony warunek 
(edycja warunkowa). 

dBase IV zawiera zupełnie zmieniony generator raportów, który 
jest w stanie spełnić nawet najbardziej wyszukane wymagania uży¬ 
tkownika. Pracuje on również w oparciu o zasadę WYSIWYG. Pro¬ 
jektowanie oparte jest na koncepcji podziału całego raportu na 
szereg warstw. Poszczególne warstwy budowane są na podstawie 
zawartości rekordów spełniających zdefiniowane kryteria. Mogą 
też być warstwami o specjalnym znaczeniu, np. wprowadzenie do 
raportu czy podsumowanie raportu. W raportach mogą być używa¬ 
ne pola obliczeniowe, pola daty, numeru pozycji, numeru strony, 
pola zawierające główki i stopki stroń oraz inne. Użytkownik ma do 
wyboru pięć typów pól sumarycznych i dwa tryby drukowania; je- 
dnowierszowy (każda pozycja wyprowadzana jest w jednym wier¬ 
szu) i wielowierszowy (każda pozycja wyprowadzana jest w kilku 
wierszach). W raportach można stosować różne opcje druku np. 
zmienny krój i wielkość czcionki oraz elementy graficzne, jak np. 
prostokątne ramki wokół wyróżnianych fragmentów. 

Opcja ASSIST, wspomagająca pracę w dBase III Plus, została 
zastąpiona bardziej wyszukanym narzędziem - systemem rozwija¬ 
nego menu - realizującym to zadanie znacznie efektywniej. Na głó¬ 
wnym ekranie tego menu (Control Cenfer^ wyświetlane są skatalo¬ 
gowane obiekty, tj. nazwy wszystkich baz danych, plików definiu¬ 
jących perspektywy, wzory formatów ekranowych, raportów, ety¬ 
kietek adresowych oraz nazwy plików zawierających programy. 
Po wybraniu obiektu, np. pliku definiującego format ekranowy, 
można wyświetlić zawartość aktywnej bazy danych w układzie 
określonym przez wybrany obiekt lub uzyskać o nim informacje, 
np. wzór formatu ekranowego. Rozwijane menu stanowi doskonałe 
uzupełnienie interpretacyjnego trybu pracy dBase IV. Udostępnia 
ono również pewne możliwości, których brak w tym trybie. 

W dBase IV zaimplementowano język SOL, stający się powsze¬ 
chnym standardem dla relacyjnych języków zapytań, stosowanych 
w systemach wyszukiwania informacji, bazujących zarówno na du¬ 
żych jak i małych komputerach. Jego najistotniejszą zaletą jest uni- 
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wersalność, wyrażająca się brakiem ścisłego przywiązania do 
struktur przeszukiwanych baz danych. Dzięki temu dostęp do in¬ 
formacji zapisanych w zbiorach dBase rv może być realizowany 
zarówno za pomocą tradycyjnych komend, jak i komend języka 
SOL. 

Programiści tworzący programy aplikacyjne w dBase rv, mogą 
duże fragmenty kodu języka dBase, realizujące wyszukiwanie da¬ 
nych, zastąpić wysokopoziomowymi konstrukcjami języka SOL. 

W dBase rv wprowadzono wiele zmian dotyczących baz da¬ 
nych, tworzonych między nimi relacji oraz metod ich indeksowa¬ 
nia. Rewelację stanowią szczególnie te ostatnie. Zastosowana w 
dBase rv metoda indeksowania umożliwia stworzenie aż 47 indek¬ 
sów w jednym zbiorze indeksowym. Zbiór zawierający wiele in¬ 
deksów (zbiór wieloindeksowy) ma w dBase IV rozszerzenie 
.MDX. Każdy indeks ze zbioru wieloindeksowego ma własną uni- 
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kalną nazwę, wyrażenie definiujące go i jest dokładnym odpowie¬ 
dnikiem indeksu zawartego w pliku o rozszerzeniu .NDX z dBase 
III Plus. Gdy definiowana jest struktura bazy danych, użytkownik 
może wyspecyfikować dowolne pola rekordu (liczba takich pól nie 
może przekroczyć 47) jako pola indeksowe. Jeżeli wyspecyfikowa¬ 
ne zostanie przynajmniej jedno takie pole, dBase IV automatycznie 
utworzy zbiór wieloindeksowy o nazwie identycznej z nazwą two¬ 
rzonej bazy danych i z rozszerzeniem .MDX. Zbiór taki można utwo¬ 
rzyć również komendą INDEX. Używanie zbioru wieloindeksowe- 
go o nazwie identycznej z nazwą bazy danych gwarantuje jego au¬ 
tomatyczne otwieranie i aktualizację, gdy otwierana jest baza da¬ 
nych, z którą jest on związany. Daje to użytkownikowi komfort pra¬ 
cy, wyrażający się w tym, że nie musi pamiętać o otwieraniu plików 
indeksowych wraz z otwieraniem bazy danych. Każdy zbiór wielo¬ 
indeksowy wyznacza tyle sposobów uporządkowania bazy da¬ 
nych, ile zawiera indeksów. Jeżeli uwzględni się również f^, że z 
bazą danych może być otwartych jednocześnie kilka zbiorów wie- 
loindeksowych, to użytkownik dysponuje niespotykanymi nigdzie 
przedtem możliwościami wykorzystywania bazy danych z prakty¬ 
cznie nieograniczoną liczbą indeksów. Oprócz zbiorów wieloin- 
deksowych można używać również klasycznych plików indekso¬ 
wych, utworzonych w dBase III Plus. Istnieje cała grupa komend, 
umożliwiających pobieranie indeksów z plików wieloindeksowe- 
go i tworzenie z nich klasycznych plików indeksowych oraz wpro¬ 
wadzanie zawartości tych ostatnich (w postaci oddzielnych indek¬ 
sów) do plików wieloindeksowych. Dzięki temu istnieje możliwość 
przetwarzania w dBase IV danych tworzonych w wersji dBase III 
Plus. 

Trudno jest, w ramach krótkiego artykułu, szczegółowo przed¬ 
stawić zmiany i rozszerzenia wprowadzone do zestawu 310 ko¬ 
mend i funkcji dBase rv. Z tego powodu w^ada wymienić tylko te 
z nich, które w znaczny sposób przyczyniają się do zwiększenia 
funkcjonalności pakietu. Są nimi: 

• komendy służące do definiowania i stosowania w aplikacjach 
systemu okien i rozwijanych menu; 

• komendy przeznaczone do definiowania i przetwarzania tablic; 

• komendy działające na bazach danych otwartych w nieaktyw¬ 
nych obszarach roboczych; 

• komenda CAŁCULATE, realizująca w jednym "przejściu” 
przez bazę danych różnorodne obliczenia finansowe i statysty¬ 
czne jak: wyznaczanie wartości średnich, maksymalnych, mini¬ 
malnych, odchylenia standardowego i innych; 

• konstrukcja SCAN/ENDSCAN, służąca do wyszukania i prze¬ 
tworzenia rekordów spełniających określone warunki. Jest ona 
łatwiejsza do zaprogramowania i wymaga mniejszej liczby in¬ 
strukcji niż równoważna jej pętla DO WHILE/ENDDO; 

• bogaty zestaw funkcji matematycznych wzbogacony o funkcje 
trygonometryczne; 

• funkcja LOOKUP(), realizująca przeszukiwanie pól rekordów 
baz danych w celu sprawdzenia, czy zawierają one określoną 
wartość. Jej wywołanie zastępuje, często złożone, konstrukcje 
programowe zbudowane z komend SEEK, IF FOUND, DO 
WHILE/ENDDO. 

Maksymalna liczba zmiennych, które można zdefiniować w dBa¬ 
se IV została zwiększona do 15000 (dBase III Plus dopuszcza zde¬ 
finiowanie 255 zmiennych). Ponadto dBase rV został wyposażony 
w znacznie ulepszony mechanizm zarządzania pamięcią zajmowa¬ 
ną przez zmienne, który przyspiesza realizację procesów związa¬ 
nych z ich obsługą. 

dBase IV w odmienny sposób niż dBase III Plus traktuje proce¬ 
dury. W dBase rv procedura może być zawarta w dowolnym pliku 
komend (.PRG), również w tym, w którym znajduje się program. W 
związku z tym nie ma konieczności tworzenia oddzielnych plików 
z kodem programu i komend procedur, wykorzystywanych przez 
ten program. Liczba procedur, które mogą być zapisane w jednym 
pliku została zwiększona z 32 do 963. Zachowano jednakże komen¬ 
dę SET PROCEDURĘ TO, otwierającą plik typu .PRG, zawierający 
procedury, które nie są dostępne po komendzie DO. Wywoływa¬ 
nie procedur może być zagnieżdżone maksymalnie do 32 pozio¬ 
mów. 

Szybkość wykonywania programów aplikacyjnych została zna¬ 
cznie zwiększona dzięki wprowadzeniu do dBase rv kompilatora. 
Tłumaczy on kod źródłowy programu oraz jego procedur i funkcji 
na kod wynikowy, zapisywany do plików z rozszerzeniem .DBG. W 
związku z tym, wykonanie tego kodu nie wymaga fazy interpretacji, 
która występow^a w każdej poprzedniej wersji dBase. Nie jest to 
jednakże "prawdziwy” kompilator. Wygenerowany przez niego 


kod wynikowy nie jest takim kodem, jaki jest zapisany w plikach 
EXE. Jego wykonanie wymaga obecności w pamięci komputera 
pakietu, albo jego biblioteki uruchomieniowej. Wersja dBase IV 
Developer’s Edition wyposażona jest w konsolidator, któ^ umo¬ 
żliwia przetworzenie kodu uzyskanego w wyniku kompilacji w kod 
wykonywalny. 

Testowanie tworzonych aplikacji zostało znacznie ułatwione po¬ 
przez wbudowanie w dBase rv debuggera. Działa on w systemie 
okien i współpracuje z komendą MODIFY COMMAND. Debug- 
ger wykorzystuje 4 okna: okno stanu, okno edycji, okno "pułapek” 
lub punktów zatrzymań i okno wyników. W olaiie stanu wyświetla¬ 
ne są informacje, opisujące środowisko pracy debuggera, tj.: naz¬ 
wa pliku zawierającego wykonywany kod programu (procedury), 
numer wykonanej linii programu, numer aktywnego obszaru robo¬ 
czego, nazwa bazy danych i zbiorów indeksowych w nim otwar¬ 
tych oraz bieżąca wartość wskaźnika rekordu. W oknie edycji wy¬ 
świetlany jest kod testowanego programu. Istnieje możliwość 
wprowadzania do niego zmian i poprawek podczas procesu testo¬ 
wania. W oknie "pułapek” użytkownik może zdefiniować maksy¬ 
malnie 10 warunków określających sytuację, w których wykony¬ 
wanie testowanego programu ma zostać przerwane. Można wów¬ 
czas sprawdzić, czy wykonana sekwencja komend daje zakładany 
rezultat. 
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P 

- Sbou progran łraceback info. 

Q 

- Ouił debugger. 

R 

- Run unłil inłerrupt or error. 

[nlS 

- Execułe nexł słałenenł. 

X 

- Exił ło DOI Pronpł. 


- Repeał last słep or nexł. 

Cnlt 

- Sbou previous linę. 

[nR 

- Sbou nexł linę. 

FI 

- loggie Connand Help On/Off. 

F9 

- Sbou User screen. 


— DEBUGGER 
Uork Area; i 
Record: 0 
ACTIW; 


Database file! 
tlasłer Index; 


Progran Pile! accłj^c. 
Procedurę: ACCTJIEC 
Currenł linę! 22 
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Szczególnie cenne z punktu widzenia użytkownika, planującego 
wykoĄjystanie dBase rv w sieci, jest wyposażenie wielu jego ko¬ 
mend i^funkcji w opcje, służące do współbieżnego wykonywania 
procesów przetwarzania danych. Jedną z takich opcji jest automa¬ 
tyczne blokowanie dostępu do plików i rekordów, realizowane 
przez takie komendy jak: APPEND, BROWSE, EDIT, CHANGE, 
RE AD i inne. Dzięki temu wielu użytkowników może jednocześnie 
przetwarzać różne fragmenty tej samej bazy danych, bez koniecz¬ 
ności fizycznego wiązania jej z określonym użytkownikiem. Rów¬ 
nież z myślą o wykorzystaniu dBase IV w lokalnej sieci komputero¬ 
wej, został on wyposażony w funkcjonalny mechanizm służący do 
ochrony integralności przetwarzanych informacji. Elementem tego 
mechanizmu jest oprócz wspomnianego automatycznego bloko¬ 
wania plików i rekordów, przetwarzanie w procesach transakcji, 
Do definiowania procesu transakcji służą komendy BEGIN...END 
TRANSACTION. Każda transakcja rozpoczynana jest komendą 
BEGIN TRANSACTION. Po jej wykonaniu każda elementarna 
operacja, wchodząca w skład transakcji jest zapisywana do specja¬ 
lnego pliku transakcyjnego. Gdy proces transakcji zostanie popra¬ 
wnie zakończony (komenda END TRANSACTION), dBase IV za¬ 
myka i kasuje związany z nim plik transakcyjny. Jeżeli jednak pro¬ 
ces transakcji nie zostanie wykonany poprawnie, użytkownik może 
odtworzyć stan bazy danych sprzed jego rozpoczęcia. Służy do 
tego komenda ROLL BACK. Informacje o błędnym zakończeniu 
procesu transakcji dBase rv zapisuje w umieszczonym w nagłów¬ 
ku bazy danych wskaźniku integracji. Wskaźnik ten wykorzysty¬ 
wany jest przez komendę USE. Na podstawie informacji w nim za¬ 
pisanej, komenda ta określa stan integralności w zbiorach, które 
użytkownik zamierza przetwarzać. Jeżeli wskaźnik integralności 
danych wskazuje, że dane mogą być niekompletne użytkownik jest 
o tym poinformowany. Może on w takiej sytuacji komendą ROLL 
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BACK przywrócić sta^ stan zbiorów lub komendą RESET zigno¬ 
rować stan wskaźnika integralności i kontynuować przetwarzanie. 

Inną cenną dla użytkownika sieciowej wersji dBase IV jest ko¬ 
menda SET REFRESH TO. Określa ona co ile sekund dBase IV ma 
sprawdzać, czy zmienione zostały informacje zapisane w zbiorach 
danych i automatycznie wyświetlać wprowadzone zmiany na ekra¬ 
nach stacji roboczych użytkowników, zainteresowanych tymi zmia¬ 
nami. Na przykład, jeżeli jeden z użytkowTiików sieci użył komendy 
BROWSE lub EDIT do edycji określonego rekordu i w tym samym 
czasie inny użytkownik wprowadził zmiany do tego rekordu, to 
zmiany te zostaną wyświetlone na ekranie użytkownika edytujące¬ 
go aktualnie ten rekord. 

Do ochrony danych przetwarzanych w sieci służy komenda 
PROTECT, umożliwiająca szyfrowanie danych, wprowadzanie sy¬ 
stemu haseł otwierających dostęp do nich i definiowania trybów 
wykorzystywania ("wyłączne”, "współużytkowne”) zbiorów da¬ 
nych. 

dBase IV może współpracować z następującym oprogramowa¬ 
niem sieciowym: IBM PC LAN Program wersja 1.2, Novell SFT 
NetWare 286 wersja 2.1, Net/One PC System wersja 15.2 i 3Com 
3+ Share Software wersja 1.2. 

W przedstawionej niżej tablicy zestawiono porównanie ważniej¬ 
szych opcji pakietów dBase III Plus i dBase IV. Jej analiza potwie¬ 
rdza ocenę dBase IV, sformułowaną we wstępie artykułu. 


Opcja 

dostępne w 

dBase III Plus 

dBase IV 

1 praca interpretacyjna 

tak 

tak 

w systemie menu 

nie 

tak 

baza danych model 

typy pól rekordu: 

relacyjny 

relacyjny 

stałoprzecinkowe 

tak 

tak 

zmiennoprzecinkowe 

nie 

tak 

znakowe 

tak 

tak 

data 

tak 

tak 

logiczne 

tak 

tak 

memo 

(funkcje działające 

tak (4KB) 

tak (64KB) 

na polach memo) 
opero wanie na polach: 

nie 

tak 

kontrola wejścia 

nie 

tak 

edycja warunkowa 
obsługa błędów wejścia 

nie 

tak 

przez użytkownika 
indeksowanie: 

nie 

tak 

automatyczne 

nie 

tak 

liczba indeksów 
tworzenie relacji 

7 

nieograniczona 

baza danych: wiele baz 
operacje na nieaktywnych 

nie 

tak (1:9) 

bazach danych 

relacyjne języki zapytań 

nie 

tak 

język SQL 

nie 

tak 

język QBE 

narzędzia usprawniające 
programowanie 

nie 

tak 

generator formatów ekran. 

tak 

tak (lepszy) 

generator etykietek adres. 

tak 

tak (lepszy) 

generator raportów 

tak 

tak (lepszy) 

generator aplikacji 

nie 

tak 

dop. liczba zmiennych 

255 

15000 

tablice 

nie 

tak 

kompilator 

nie 

tak 

debugger 

nie 

tak 

biblioteka uruchomieniowa 
możliwość definiowania 

nie 

tak 

funkcji użytkownika 

nie 

tak 

liczba procedur w pliku 

cechy tworzonych aplikacji 

32 

963 

kontrola edycji pól memo 
aktywny system pomocy 

nie 

tak 

uwzg. kontekst pracy 

nie 

tak 

praca wsys. okien 

nie 

tak 

opcje sieciowe 

tak 

tak (znacznie 
rozbudowane) 


Autorzy pragną wyrazić podziękowanie firmie Eurobit za udostępnienie roboczej 
wersji opracowania na temat dBase IV. 
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Zagadnienie sztucznej inteligencji ma znacznie dłuższy rodowód 
niż technika komputerowa. Rozważano je już w starożytności, oczy¬ 
wiście w sferze czysto spekulacyjnej. Później przeszło do mitclogii 
(Golem), by w XIX w. powrócić do sfery problemów technicznych. 
Podejście to zapoczątkował Charles Babbage tworząc koncepcję 
algorytmizacji problemów, to jest podziału ich na tak małe części, 
aby dały się one rozwiązać w sposób ścisły i jednoznaczny za po¬ 
mocą pewnych procedur, a następnie uzyskania rozwiązania cało¬ 
ściowego na podstawie otrzymanych rozwiązań częściowych. W 
owym czasie jednak idea ta nie mogła być wykorzystana praktycz¬ 
nie z powodu niedostatecznego rozwoju techniki. 

Problem sztucznej inteligencji powrócił w latach trzydziestych 
naszego stulecia. Impuls do tego dał Allan Turingw swoim artykule 
”Czy maszyna może myśleć?”. Udzielając zasadniczo pozytywnej 
odpowiedzi na tak sformułowane pytanie stał się patronem dal¬ 
szych prac w tej dziedzinie, podjętych niemal równocześnie z uru¬ 
chomieniem pierwszych komputerów. Dało to początek dyscypli¬ 
nie naukowej zwanej dzisiaj sztuczną inteligencją (Al- artificialin- 
telligence). 

Pierwsze prace w tej dziedzinie miały na celu tworzenie progra¬ 
mów posiadających duży stopień ogólności, mogących rozwiązy¬ 
wać problemy o różnorodnej strukturze z dowolnych gałęzi wie¬ 
dzy. Największym osiągnięciem był Logic Theorist Newella, Sha- 
wa i Simona, potrafiący dowodzić twierdzenia z dziedziny logiki 
pierwszego rzędu za pomocą operacji na symbolach. Jednakże 
dalszy rozwój w tym kierunku okazał się znikomy; próby stworze¬ 
nia programu rozwiązywania wszelkich zadań (GK - General Pro¬ 
blem Solver) okazały się nieudane. 

Drugim kierunkiem rozwoju badań nad sztuczną inteligencją 
było modelowanie sieci nerwowej i mózgu ludzkiego. Zaowocowa¬ 
ło to takimi symulatorami jak kognitron i perceptron, które były 
pierwszymi urządzeniami do automatycznego rozpoznawania 
obrazów. Jednak i w tym przypadku koniec lat pięćdziesiątych wy¬ 
znaczał okres szczytowych osiągnięć, po których nie nastąpiły już 
dalsze. Oczywiście oba wspomniane kierunki badań są w dalszym 
ciągu kontynuowane, ale nie nastąpił jeszcze czas ich renesansu. 

Od połowy lat sześćdziesiątych w centrum badań nad sztuczną 
inteligencją znalazło się zagadnienie "rozumienia” przez maszyny, 
zwykle w sensie rozumienia języka naturalnego i możliwości pro¬ 
wadzenia dialogu z człowiekiem. Zagadnienie to - jak zwykle bywa 
- spowodowało powstanie wielu nowych kwestii, wśród których 
zasadniczymi były sposoby reprezentacji wiedzy i reguły wniosko¬ 
wania o świecie. O ile samo pojęcie "maszynowego rozumienia” 
pozostaje w dalszym ciągu sporne, o tyle rozwiązanie — aczkolwiek 
częściowe - wspomnianych wyżej problemów legło u podłoża ros¬ 
nącej grupy programów, zwanych dzisiaj systemami ekspertowy¬ 
mi. 


Rozwój systemów ekspertowych 

Historia systemów ekspertowych w dzisiejszym tego słowa zna¬ 
czeniu zaczyna się w ... No właśnie. Jak zwykle bywa, podanie ści¬ 
słej daty jest trudne. Opis pierwszego programu symbolicznego 
całkowania (SAINT - Symbolic Automatic Integrator) podał Slagle 
w swojej dysertacji w 1961 roku. Natomiast pierwszy stosowany do 
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dzisiaj doskonały system DENDRAL, dokonujący analizy struktury 
chemicznej cząsteczek na podstawie wyników badania magnety¬ 
cznego rezonansu jądrowego, został ukończony przez Feigenbau- 
ma w 1975 roku. Ta ostatnia data jest często uznawana jako począ¬ 
tek epoki systemów ekspertowych, ale jak widać jest to sprawa 
sporna. Nie ulega jednak wąpliwości, iż od połowy ubiegłego dzie¬ 
sięciolecia można mówić o ich istnieniu w wersji użytkowej (a także 
handlowej, co jest nie bez znaczenia dla dalszego rozwoju tej dzie¬ 
dziny badań nad sztuczną inteligencją). 

Wspomniane wyżej systemy zapoczątkowały szybki rozwój tej 
dziedziny badań. DENDRAL, nad którym prace zapoczątkowano 
na Uniwersytecie Stanford w 1965 roku, jest stosowany do dzisiaj i 
jego możliwości przewyższają większość specjalistów-chemików. 
Dla podniesienia efektywności działania stworzono system 
META-DENDRAŁ, umożliwiający kontrolę poprawności stoso¬ 
wanych reguł wnioskowania i ich użyteczności w analizie struktury 
cząsteczki. Tak wzbogacony system jest stosowany w wielu ośrod¬ 
kach akademickich i instytutach badawczych. 

SAINT jest przykładem innej drogi rozwojowej. Wielokrotnie 
modyfikowany przekształcił się w połowie lat siedemdziesiątych w 
system ekspertowy dla wykonywania operacji matematycznych 
znany pod nazwą MACSYMA. Stworzony w MIT * jest również 
szeroko stosowany przez matematyków i fizyków - wykonuje cał¬ 
kowanie i różniczkowanie w sposób symboliczny. 

Ważną dziedziną zastosowań systemów ekspertowych jest me¬ 
dycyna. Dla jej potrzeb powstało kilka znanych systemów. INTER- 
NIST, jak sama nazwa wskazuje, służy pomocą przy diagnostyce 
chorób wewnętrznych. CASNET jest przeznaczony dla wspoma¬ 
gania diagnostyki i leczenia jaslóry. CADUCEUS jest systemem 
specjalizowanym w wąskim dziale interny. Najbardziej jednak zna¬ 
nym spośród nich jest stworzony w Stanford system MYCIN dla 
diagnostyki i leczenia infekcyjnych chorób krwi. 

Zastosowane w systemie MYCIN środki semantyczne okazały 
się tak efektywne, że powstało wiele różnorodnych systemów po¬ 
chodnych. TEIRESIAS na przykład pomaga przy tworzeniu du¬ 
żych baz danych, przy czym di^og z człowiekiem - specjalistą od¬ 
bywa się w języku naturalnym. Problemowo niezależny wariant sy¬ 
stemu zwany EMYCIN jest generatorem przykładowych diagno¬ 
stycznych systemów ekspertowych jak PUFF. System PROSPEC- 
TOR, przeznaczony dla analizy danych geologicznych w celu wy¬ 
szukiwania złóż cennych kopalin - przyniósł zyski rzędu stu milio¬ 
nów dolarów. Wreszcie pochodną systemu h^CIN jest ROSIE - 
uniwersalny system programowania dla tworzenia systemów ek¬ 
spertowych. Bogactwo zastosowanych w nim środków czyni posłu¬ 
giwanie się ROSIE łatwym, a możliwości zastosowania bardzo sze¬ 
rokimi. 

Na Uniwersytecie Camegie-Mellon powstała seria języków 
OPS, wywodząca się z języka PSG i wykorzystywana dla modelo¬ 
wania poznawczej dziialności człowieka. Odgałęzieniem tej ro¬ 
dziny jest system R1 projektowania konfiguracji zestawów VAX 
firmy DEC. R1 jest przykładem najbardziej udanego wykorzysta¬ 
nia języka do stworzenia systemu ekspertowego. 

Dla rozumienia mowy ludzkiej skonstruowano system HEAR- 
SAY-II, którego możliwości pozwalały porównać go z dziesięciole¬ 
tnim dzieckiem. Mimo jego niedostatków podstawowe idee ko- 
strukcyjne okazały się płodne i są stosowane w innych systemach 
rozpoznawania. Pochodne od rozpatrywanego tu systemu są HE- 
ARSAY-III i AGE - uniwersalne schematy pozwalające tworzyć 
nowe systemy ekspertowe. 

Obecnie powstaje coraz więcej nowych systemów eksperto¬ 
wych i wyliczenie wszystkich byłoby zadaniem trudnym. Trzeba 
jednak zauważyć, że są to często systemy bardzo wąskie a ich kon¬ 
strukcja opiera się na założeniach sformułowanych dla systemów 
powstałych wcześniej. Przykładami mogą służyć: MECHO dla roz¬ 
wiązywania zagadnień z mechaniki newtonowskiej nieba czy PI- 
COT dla sterowania ruchami robota w dynamicznie zmieniającym 
się środowisku. Powstaje ich coraz więcej i można przewidywać, 
że proces ten będzie narastał. 

Co to jest 

system ekspertowy? 

Przez system ekspertowy rozumiemy program komputerowy 
posiadający wiadomości i przeprowadzający wnioskowanie w pe¬ 


wnej dziedzinie wiedzy takiej, jak medycyna czy geologia, z możli¬ 
wością rozwiązywania problemów oraz doradztwa. Od progra¬ 
mów z innych dziedzin sztucznej inteligencji różni się następujący¬ 
mi elementami: 

• ma do czynienia z zagadnieniami rzeczywistymi o takim stopniu 
złożoności, że wymagają one zwykle dużej wiedzy ludzkiej: 

• musi osiągać wysoką jakość działania pod względem szybkości 
i niezawodności, aby być użytecznym narzędziem; 

• musi być w stanie wyjaśnić i uzasadnić rozwiązania i zalecenia, 
aby przekonać użytkownika, że rozwiązanie jest rzeczywiście 
poprawne. 

Aby zrealizować powyższe cele system ekspertowy musi zawie¬ 
rać takie części jak: 

• wiedza z danej dziedziny (zbiór faktów); 

• reguły wnioskowania (tworzące wraz z faktami bazę wiedzy); 

• maszyna wnioskująca; 

• kontroler poprawności: 

• dogodny dla użytkownika sposób prowadzenia dialogu. 
Wszystkie one powinny działać w sposób, pozwalający spełnić 

warunki podane na początku. Poniżej podajemy ich krótką charak¬ 
terystykę. 

Sposób prowadzenia dialogu 

Użytkownik współdziała z systemem ekspertowym w problemo¬ 
wo zorientowanym języku - zwykle wariancie języka naturalnego - 
przez odpowiedni procesor językowy. Procesor ten prowadzi gra¬ 
matyczny rozbiór pytań, poleceń i innych wypowiedzi użytkownika 
oraz dokonuje ich interpretacji dla potrzeb systemu. Gromadzi tak¬ 
że uzyskane informacje. Z drugiej strony formułuje dla użytkowni¬ 
ka informacje generowane przez system, włączając w to odpowie¬ 
dzi na pytania, objaśnienia i uzasadnienia swoich odpowiedzi a tak¬ 
że żądania informacji. W większości stosowanych obecnie syste¬ 
mów procesor językowy jest tworzony w języku INTERLISP. 
Oprócz opisanego rozwiązania, komunikacja może odbywać się w 
trybie graficznym, za pomocą programu-redaktora, lub za pomocą 
tahlicy komunikatów. Przyjęcie konkretnego rozwiązania zależy 
od problemu i łatwość posługiwania się nim w konkretnej sytuacji 
jest podstawą wyboru. 

Baza wiedzy 

Właściwie skonstruowana baza wiedzy jest podstawą dobrego 
działania systemu ekspertowego. Wspomniane we wstępie odcho¬ 
dzenie od bardzo ogólnych systemów rozwiązywania problemów 
wiązało się z tworzeniem bogatych baz danych w wąskich dziedzi¬ 
nach. Tak na przykład CADUCEUS zawiera w swojej bazie danych 
wiedzę medyczną w dziedzinie chorób narządów wewnętrznych, 
pozwalającą prawidłowo rozpoznać około 85% przypadków. 

Baza wiedzy jest zbudowana z dwóch rodzajów składników. Je¬ 
den to fakty będące opisem wiedzy ekspertów w danej dziedzinie. 
Drugi zaś to reguły wnioskowania, pozwalające przechodzić od je¬ 
dnych faktów do innych i wyciągać konkltizje. Reguły te stanowią 
istotę wiedzy eksperta-człowieka i ich uzyskanie stanowi podsta¬ 
wowy problem przy tworzeniu systemu ekspertowego. W niektó¬ 
rych systemach reguły wnioskowania mają charakter procedur i 
wtedy fakty grają rolę bierną. 

Maszyna wnioskująca 

Postawiony przed systemem problem musi być rozwiązany za 
pomocą pewnej strategii. Zbiór możliwych strategii można nazwać 
zbiorem metareguł. Do danych początkowych stosowana jest jed¬ 
na ze strategii, a efektem działania jest sformułowanie pewnej (ra¬ 
czej niewielkiej) liczby najbardziej prawdopodobnych hipotez. 
Sprawdzenie tych hipotez wymaga nowych faktów, których poda¬ 
nia system żąda od otoczenia. Dodatkowe informacje mogą być 
podane przez użytkownika, przekazane bezpośrednio z urządzeń 
wejściowych lub pobrane z pamięci - zależy to od sposobu ckiiała- 
nia systemu. Zestaw procedur odpowiedzialnych za właściwe dzia¬ 
łanie systemu w sensie przeszukiwania przestrzeni możliwych roz¬ 
wiązań tworzy moduł wnioskowania. 

Kontroler poprawności 

Moduł ten na bieżąco sprawdza niesprzeczność przyjętych hipo- 
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tez (to jest możliwych rozwiązań) oraz stosowanych do ich otrzyma¬ 
nia reguł wnioskowania. W większości stosowanych systemów 
niesprzeczność rozumiana jest jako pewien poziom wiarygodnoś¬ 
ci, co wiąże się z przypisywaniem regułom wnioskowania prawdo¬ 
podobieństwa ich prawdziwości (liczby z przedziału <0, 1>). Sto¬ 
sowanie schematów obliczania wiarygodności rozwiązania końco¬ 
wego za pomocą obliczania wiarygodności rozwiązań częścio¬ 
wych, pozwala na ocenę rozwiązania pod względem jego prawdo¬ 
podobieństwa. 

Inne elementy 

Często stosowanym i w wielu wypadkach przydatnym składni¬ 
kiem systemu jest moduł uzasadniający jego działania. Odpowiada 
on na pytania, dlaczego pewne wnioski zostały przyjęte, lub dla¬ 
czego alternatywy zostały odrzucone. W module tym zwykle stwa¬ 
rza się możliwość wstecznego przeglądu wszystkich częściowych 
rozwiązań, leżących na ścieżce rozwiązania końcowego. Każdy 
krok na tej ścieżce odpowiada zastosowaniu jednej reguły wnios¬ 
kowania. Wykorzystując standardowy zestaw odpowiedzi na pyta¬ 
nia moduł przedstawia uzasadnienie w języku naturalnym. 
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PROCESOR 
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REGUŁY 
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MODUŁ 

UZASADNIANIA 
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CZĘŚCIOWE 
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Rys. 1. Elementy składowe systemu ekspertowego. 


W trakcie pracy system wykorzystuje wiele informacji, w tym 
także tę, którą sam wytwarza. Musi być ona przechowywana do 
czasu uzyskania rozwiązania problemu, lub dłużej - jeśli użytkow¬ 
nika interesuje sposób uzyskania rozwiązania. Często wszystkie te 
informacje przechowywane są w specjalnie zorganizowanej tabli¬ 
cy. Mieszczą się na niej elementy strategii, uzyskana wiedza i częś¬ 
ciowe rozwiązania wraz z drzewem dojścia. Taka organizacja utru¬ 
dnia tworzenie systemu, ułatwia natomiast jego działanie. Tak więc 
budowę systemu ekspertowego można przedstawić tak, jak na ry¬ 
sunku. 

Tworzenie systemu ekspertowego 

Twórcy systemów ekspertowych stają przed czysto empirycz¬ 
nym zadaniem rozwiązania problemu wymagającego dużej wie¬ 
dzy, nawyków i intuicji. Doprowadzając rozwiązanie do postaci 
ostatecznej muszą przy tym przedstawić je w formie działającego 
systemu. Jakkolwiek systemy różnią się od siebie wieloma elemen¬ 
tami, to ich konstrukcja opiera się na wspólnej podstawie metodo¬ 
logicznej i wykorzystuje zbliżone środki instrumentalne. 

Metodologia budowy systemów ekspertowych 

Systemy ekspertowe powstają w trakcie procesu o charakterze 
ewolucyjnym. Pierwszą przyczyną jest wieloetapowość tego pro¬ 
cesu, złożonego z kilku dających się wyodrębnić części. Drugą zaś 
- konieczność empirycznego testowania przyjętych rozwiązań, co 
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w praktyce oznacza często powrót do wcześniejszych etapów i po¬ 
prawę przyjętych tam rozstrzygnięć. Przyczyny te prowadzą rów¬ 
nocześnie do określonego toku pracy nad konstrukcją systemu. 

Podstawową kwestią w konstrukcji systemu ekspertowego jest 
uzysk^ie dostatecznej wiedzy w przedmiocie, w którym ma on 
działać. Zajmuje się tym inżynieria wiedzy. Jej przedstawiciel 
współdziała ze specjalistami w danej dziedzinie, określając zakres 
wiedzy niezbędny dla poprawnego funkcjonowania systemu, re¬ 
guły wnioskowania i strategie rozwiązywania problemów. Prowa¬ 
dzone są obecnie prace nad automatyzacją procesu pozyskiwania 
wiedzy, ale w bliskiej perspektywie nie uda się najprawdopodob¬ 
niej wy]ść poza wspomaganie, gdyż występuje zbyt wiele skompli¬ 
kowanych problemów z tym związanych. 

W tabeli przedstawione są wspomniane wyżej etapy powstawa¬ 
nia systemu ekspertowego. 


IDENTYFIKACJA 

określenie charakterystyk zadania | 

KONCEPTUALIZACJA 

znalezienie pojęć dla przedstawienia wiedzy] 

FORMALIZACJA 

opracowanie struktur dla organizacji wiedzy] 

REALIZACJA 

sformułowanie reguł, wyrażających wiedzę ] 

WERYFIKACJA 

ocena poprawności reguł ] 


Identyfikacja polega na właściwym postawieniu problemu, któ¬ 
ry będzie rozwiązywany przez planowany system. Na tym etapie 
inżynier wiedzy współpracuje z ekspertem nad wydzieleniem ob¬ 
szaru zainteresowań, a co za tym idzie niezbędnych dla systemu in¬ 
formacji. Ustala się uczestników procesu tworzenia systemu (na 
przykład innych ekspertów), ograniczenia i potrzebne środki. 

W fazie opracowama koncepcji inżynier wiedzy wraz z eksper¬ 
tem określają podstawowe pojęcia, relacje i sposób przepływu in¬ 
formacji - wszystko to, co jest niezbędne dla prawidłowego roz- 
wiąz^ania problemów z danej dziedziny. Na tym etapie określone 
zostają stosowane strategie, czyli najważniejsza część systemu, od 
której prawidłowego działania zależy jego skuteczność. 

Formalizacja zagadnienia jest dotychczas rozumiana jako przed¬ 
stawienie podstawowych pojęć i relacji z danej dziedziny w pew¬ 
nym formaliźmie, dostępnym dla inżyniera wiedzy; na ogół jest nim 
jakiś język programowania. Jednakże takie postawienie zagadnie¬ 
nia wydaje się dalece niewystarczające, gdyż jest ograniczone do 
samego przedstawienia. Tymczasem widoczny jest trend formali¬ 
zacji samych problemów, które należy rozwiązać. Perspektywa 
stosowania systemów ekspertowych, stosujących modele formal¬ 
ne dla rozwiązania postawionych przed nimi problemów wydaje 
się być całkiem realna, choć dopiero za jakiś czas. 

Realizacja systemu oznacza implementację przyjętych struktur w 
taki sposób, aby rezultat w ogólnym zarysie był zgodny z oczeki¬ 
waniami, to znaczy, by uzyskana wstępna wersja systemu nadawa¬ 
ła się do poprawy, nie zaś do kosza. Na tym etapie dopasowywuje 
się formalne struktury do charakterystyki przepływu informacji w 
systemie. 

Ostatnią czynnością jest weryfikacja, w trakcie której dokonuje 
się oceny pracy wstępnej wersji systemu ze względu na przyjęte 
przez specjalistów-ludzi kryteria jego poprawności. Ponieważ 
zwykle działanie tej wersji jest o wiele gorsze niż przypuszczali naj¬ 
więksi pesymiści wśród jej twórców, następuje powrót do wcześ¬ 
niejszych etapów w celu ulepszenia przyjętych wówczas rozwią¬ 
zań. Powraca tu współpraca inżyniera wiedzy z ekspertami, którzy 
niejednokrotnie ze zdziwieniem stwierdzają znaczną rozbieżność 
między ich wyobrażeniami o swojej dziedzinie, a rzeczywistością. 

Oczywiście"przedstawiony tu podział na etapy nie jest ani całko¬ 
wicie precyzyjny (jedno stadium pracy przechodzi w drugie w spo¬ 
sób raczej ciągły), ani jedynie możliwy. Zaproponowany w pracy 
[H] pozwala jednak uzyskać orientację w organizacji procesu two¬ 
rzenia systemu ekspertowego. 

Narzędzia do tworzenia systemów ekspertowych 

Języki stosowane do tworzenia systemów ekspertowych mają 
różnorodny charakter, tak jak różne są stawiane im zadania i spo¬ 
soby ich realizacji. Ze względu jednak na wygodę prawie wszyst¬ 
kie - wyłączając języki rodziny OPS - wykorzystują środowisko 
programowe INTERLISP. 

W zasadzie tworzenie systemu ekspertowego może się odby¬ 
wać na bazie dowolnego języka programowania. Jednakże sama 
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struktura języka może ułatwiać lub utrudniać pracę inżyniera wie¬ 
dzy. Ponadto pamiętać trzeba, że system może wykorzystywać kil¬ 
ka języków; na przykład DEPLOMAT (system do projektowania 
programowalnych macierzy logicznych) napisany jest w języku 
LISP, korzysta zaś z procedur napisanych w PROLOGU i w C. 

Rozważając zagadnienie języków dla systemów ekspertowych 
zauważyć n^eży, że występuje tu kilka poziomów. Na najwyższym 
lokują się języki będące same szkieletowymi systemami eksperto¬ 
wymi - można je nazwać systemami wiedzy. Zaliczają się do nich: 
EMYCIN, KAS, EXPERT (reguły wnioskowania typu warunkowe¬ 
go, podstawowe zastosowanie to diagnostyka), OPS5 (reguły wnio¬ 
skowania typu produkcji, uniwersalny), ROSIE (reguły wnioskowa¬ 
nia typu warunkowego, uniwersalny), AGE (reguły typu warunko¬ 
wego, rozszerzenie LISPU, szczególnie przydatny do konfigurowa¬ 
nia systemu w zależności od zadania). 

Drugi poziom stanowią języki tworzące środowisko programo¬ 
wania. Podstawowym językiem tego typu jest INTERLISP, a ostatni¬ 
mi laty coraz bardziej popularny staje się PROLOG. Języki te służą 
do ułatwienia budowy systemów ekspertowych. 

Trzeci, najniższy poziom tworzą klasyczne języki programowa¬ 
nia, w których tworzone są podstawowe części systemów eksper¬ 
towych. Najczęściej stosowany jest LISP, lecz istnieją także syste¬ 
my w PASCALU, C, a także w FORTRANIE. 

Ze względu na istniejące różnice w sposobie wypowiadania się 
człowieka i maszyny zagadnienie komunikowania się systemu ek¬ 
spertowego z użytkownikiem ma duży wpływ na możliwości prak¬ 
tycznego wykorzystania systemu. Dlatego też niezbędne są proce¬ 
dury ułatwiające wspomnianą komunikację. Oczywiście idealnym 
rozwiązaniem byłoby prowadzenie dialogu w języku naturalnym z 
wykorzystaniem przez system kanału akustycznego. Jest to jednak 
na razie nierealne i w rzeczywistości stosuje się monitor oraz kla¬ 
wiaturę. Stosowane w tym kanale narzędzia to procedury graficzne 
i sposób organizacji ekranu. Ważna jest także odpowiednia baza 
tekstowa, to znaczy zbiór komunikatów, które system może prze¬ 
słać użytkownikowi wraz ze sposobem jej wykorzystania. Progra¬ 
my te nie mają oczywiście wpływu na działanie systemu eksperto¬ 
wego w jego właściwej roli, mogą jednak decydować o przydatno¬ 
ści praktycznej. Użytkownik to przecież często osoba niezaintere- 
sowana tajnikami konstrukcji komputerów. Wymienione tu narzę¬ 
dzia pomocnicze winny czynić system "przyjaznym” i odpornym na 
błędne działanie użytkownika. 

W następnym numerze o kryteriach oceny, automatyzacji proce¬ 
su tworzenia bazy danych i perspektywach rozwoju systemów ek¬ 
spertowych. 


Massachusetts Institute of Technology 

Ps. Zbieżność nazwisk - autora i jednego z naszych kierowników działu jest przypadkowa. 
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i wielozadaniowość 


Wielodostęp zwykle kojarzony jest z wielozadanio- 
wością, czyli możliwością równoległego wykonywania 
przez jeden komputer różnych programów użytko¬ 
wych. Każde zadanie ma swój własny obszar pamięci 
na kod, stos i dane oraz zwykle dołączony terminał. 
Często jednak zachodzi potrzeba dostępu do jednej, 
wspólnej bazy danych przez kilku operatorów. 

Rozwiązywanie tego problemu poprzez wielodostęp związany z 
wielozadaniowością jest kosztowne. Każde zadanie potrzebuje sto¬ 
sunkowo dużej pamięci, co powoduje, że np. do komputera ze stan¬ 
dardową pamięcią 640 KB, pracującego pod nadzorem nakładki 
MultiLink, na którym działa program dBase III lub program skom¬ 
pilowany za pomocą Clippera, można praktycznie podłączyć jeden 
terminal. Poza tym powstają duże problemy związane z zapewnie¬ 
niem bezpiecznego dostępu do wspólnej bazy danych. 

Celem tego artykułu jest przedstawienie pewnej propozycji two¬ 
rzenia wielodostępnych programów w języku Pascal. Jest to meto¬ 
da bardzo oszczędnej gospodarki pamięcią operacyjną kompute¬ 
ra (tyle co zwykły program pascalowy, wykonujący dane zadanie 
plus ok. 16 KB dla każdego terminala). Wynika to z faktu istnienia 
w komputerze tylko jednej kopii kodu programu. W efekcie ogra¬ 
niczeniem liczby terminali jest praktycznie szybkość komputera i 
liczba łączy szeregowych. Możliwe jest również łatwe zorganizo¬ 
wanie mechanizmów blokady dostępu do wybranych zasobów 
bazy danych. 

Proces realizacji programu, tzn. proces wykonywania kolejnych 
poleceń określonych przez kod programu, z wykorzystaniem ob¬ 
szaru danych i mechanizmu stosu maszynowego, nazywany będzie 
dalej procesem. Niezmiennikieni tego procesu jest kod programu, 
a o bieżącym stanie procesu decydują pozostałe struktury. Zatem, 
dla zorganizowania kilku równoległych procesów związanych z 
tym samym kodem programu, konieczne jest zwielokrotnienie ob¬ 
szarów danych i stosu. Obszary te relokowane są dynamicznie w 
fazie inicjacji, a ich adresy zapamiętane w odpowiednich tablicach. 

Równoległa realizacja kilku procesów przez komputer z jednym 
procesorem jest możliwa przy zastosowaniu podziału czasu, czyli 
cyklicznego uaktywniania kolejnych procesów. Zmiana procesu 
polega na zachowaniu wskaźnika stosu, wyznaczeniu numeru na¬ 
stępnego procesu i załadowaniu wskaźnika stosu wg schematu: 


StackRr [ User ] 

User 

SS:SP 

Data 


<-SS:SP 

<- NextUser(User) 
<- StackPtr [ User ] 
<- DataPtr [ User ] 


Wskaźnik Data wyznacza obszar danych statycznych związa¬ 
nych z danym procesem. W przedstawionym rozwiązaniu obszar 
ten jest opisany przez rekord typu DataType, definiowany zależnie 
od potrzeb. W rekordzie tym należy umieszczać tylko duże struktu¬ 
ry danych, które nie mieszczą się w obszarze stosu maszynowego. 
Obszary danych będące zmiennymi lokalnymi funkcji i procedur, 
jako alokowane na stosie maszynowym, przełączane są automaty¬ 
cznie razem z nim. 

Do przełączania procesów służą procedury NextJobl i NextJob. 
Pierwsza z nich zmienia proces przy każdym wywołaniu, druga - 
nie częściej niż 18 razy na sekundę. Wywołąnia tych procedur nale¬ 
ży umieszczać w takich miejscach programu, aby uzyskać cykliczne 
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uaktywnianie procesów niezależnie od wykonywanego fragmentu 
programu. W szczególności procedura NextJobl musi znajdować 
się w pętli oczekiwania funkcji ReadKey, a procedura NextJob w 
odpowiedniej procedurze obsługi kanału Output. 

Periodyczne przerwanie sprzętowe związanie z wektorem ICh 
procesora o częstotliwości 18,2 Hz wykorzystywane jest do inkre- 
mentacji licznika Clock oraz do sprawdzenia wszystkich wejść 
szeregowych RS232C. Licznik Clock wykorzystywany jest przez 
procedurę NextJob w celu uzyskania równomiernego podziału 
czasu. 

Redefinicji muszą ulec wszystkie funkcje i procedury komunika¬ 
cji z konsolą operatora. Dotyczy to funkcji ReadKey i KeyPressed, 
procedur: ClrScr, ClrEol, GotoXY, DelLine, InsLine oraz ewen¬ 
tualnie procedury Window. Konieczna jest również modyfikacja 


r 


program MultiProcessing; 
uses MProcLib, UserProc; 

{$F+} 

proceduro MainProcess; 

{$F-} 

var Act : Boolean; 

Ch : Char; 

begin 

repeat 

Enable; 

UserProcedure; 

Disable; 

Act := False; 
repeat 

NextJobl; 

if KeyPressed then begin 
Ch := ReadKey; 

if Master and (Ch = "C) then Halt; 
if Ch = ESC then Act := True; 
end; 

until AllDisabled or Act; 
until AllDisabled; 
while not Master do NextJob1; 

Hal t; 
end; 


begin 

MainProcessPtr 
NextJob1; 
end. 

unit MProcLib; 
interface 


:= Addr(MainProcess); 


uses 

const 


type 


Crt, Dos; 
MaxUser 
StaclcDepth = 
OueueLength = 
ESC 

AlphaLen 
Clockint 
Alpha 
Users 
Stac)c 
QueueType 


8 ; 

16384; 

20 ; 

#27; 


= 16 ; 


DataType 


var 


DataTypePtr = 

MaxActiveUser 

User 

Clock 

LastClock 

StackPtrs 

StackSegs 

Data 

DataPtrs 

Started 

Active 

Queue 

Master 

OldClockPtr 

01dExitProc 

TConOutPtr 

TConFlushPtr 

MainProcessPtr 


$1C; 

string(AlphaLen]; 

0..MaxUser; 

array [0..StackDepth] of Integer; 
record 

Buf : array [0..QueueLength] of char; 
QueueStart :Integer 
QueueEnd : Integer 
QueueLen : Integer 
end; 
record 

{ User defined data } 
end; 

“DataType; 

Integer; 

Users; 

Integer; 

Integer; 
array ( Users 
array [ Users 
DataTypePtr; 
array [ Users 
array ( 
array ( 
array { 

Boolean 
Pointer 
Pointer 
Pointer 
Point sr 


Users 

Users 

Users 


of Integer; 
of Integer; 

of DataTypePtr; 
of Boolean; 
of Boolean; 
of OueueType) 


Pointer 


proceduro 

proceduro 

function 

function 

function 

procedurę 

proceduro 

procedurę 

procedurę 

procedurę 

procedurę 


NextJob1; 

NextJob; 

KeyPressed : Boolean; 
ReadKey : Char; 
AllDisabled : Boolean; 
Enable; 

Disable; 

GotoXY(X, Y 
ClrEol; 

ClrScr; 

TrueYideo; 


Integer) 


FlushFunc := TConFlushPtr; 

Write(Ch) ; 

InOutFunc := ConOutPtrLoc1; 

FlushFunc := Con0utPtrLoc2; 

^nd 

else SendChar(Ch); 
end; 

{$F.} 

function ConOutFunction(var F : TextRec) : Integer; 
{$F-} 

var P,BP : Integer; 
begin 

with F do begin 

BP := BufPoS; BufPos := 0; 

for P := 0 to BP - 1 do OutputChar(BufPtr“(P)); 
end; 

ConOutFunction := 0; 
end; 


: Integer; 


{$F>} 

function FlushFunction(var F : TextRec) 
{$F-} 
begin 

FlushFunction := ConOutFunction(F); 
NextJob; 
end; 


{$F.} 

procedurę ExitMainProcess; 

{$F-} 

begin 

ClockInterruptsOff; 

TextRec(Output).FlushFunc := Addr (ConOutFunction); 

{ Task change disabled during Write } 
for User:=0 to MaxActiveUser do begin 
Master := (User = 0); 

ClrScr; InvVideo; GotoXY(33,12); 

Write(• KONIEC ’); 

TrueYideo; GotoXY(1,20); 
end; 

ExitProc := 01dExitProc; 
end; 

procedurę InitMainProcess; 
var P : Pointer; 

String(5]; 

Integer; 


S 

B,Baud 
begin 

MainProcessPtr := Nil; 

MaxActiveUser ;= 0; 
if ParamCount >= 1 then begin 

Yal(ParamStr(1),MaxActiveUser,B); 
if (B = 0) and (MaxActiveUser > MaxUser) then 
MaxActiveUser := MaxUser; 

end; 

if ParamCount >= 2 then begin 
Yal(ParamStr(2),Baud,B); 

if B = 0 then BaudRate(Baud) else BaudRate(9600) 
end; 

LastClock := 0; Clock := 1; 
for User:=0 to MaxActiveUser do begin 
Started [User] := False; 

New( DataPtrs [User] ); 
with Queue [User] do begin 


QueueStart 

end; 

Active [ User 
end; 

TConOutPtr ;= 
TConFlushPtr := 
TextRec(Output) 


= 0; OueueEnd := 0; QueueLen := 0; 
] := False; 


TextRec(Output).InOutFunc; 

TextRec(Output).FlushFunc; 
InOutFunc := Addr(ConOutFunction) 
TextRec(Output).FlushFunc := Addr(FlushFunction); 
for User :'= 1 to MaxActiveUser do begin 
GetMem(P,StackDepth); 

StackSegs [ User ] := Seg(P''); 

StackPtrs [ User ] := StackDepth - 20; 

end; 

User := 0; Master := True; 

Data := DataPtrs [User]; 

01dExitProc := ExitProc; 

ExitProc := Addr(ExitMainProcess); 
ClockInterruptsOn; 
end; 

function AllDisabled : Boolean; 
var u : Users; 

A : Boolean; 
begin 

A := True; 

for U : = 0 to MaxActiveUser do 
if Active [ U ] then A := False; 

AllDisabled := A; 
end; 

procedurę Enable; 
begin 

Active [ User 
end; 

procedurę Disable; 
begin 

Active [ User 
ClrScr; 

if not AllDisabled then begin 
GotoXY(12,11); 

Writef'Oczekiwanie na zamkniecie zadań 


] :^ True; 


] := False; 
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procedurę InvVideo; 
procedurę InsLine; 
procedurę DelLine; 

iraplementation 

const Address : array [l..MaxUserl of Integer = 

($3F8, $2F8, $3E8, $2E8, $280, $288, $290, $298); 
var CallProcBufPtr : Pointer; 

NJBuf : Word; 

procedurę CallProc(P : Pointer); 
begin 

CallProcBufPtr := P; 

Inline($FF/ $1E/ CallProcBufPtr); 
end; 

procedurę EnterMainProcess; 
begin 

if MainProcessPtr o Nil then CallProc(MainProcessPtr) 
end; 

procedurę Scaninput; forward; 
function NextUser : Users; 
begin 

if User < MaxActiveUser then NextUser := User ♦ 1 

else NextUser := 0; 

end; 

procedurę NextJobl; 
begin 

if Master then Scaninput; 

inline( $89/ $2E/ NJBuf); { MOV [NJBuf],BP } 

StackPtrs [ User ] := NJBuf; 

StackSegs [ User ] := SSeg; 

DataPtrs [ User j := Data; 

User := NextUser; 

Master -. = (User = 0); 

Data := DataPtrs [ User ]; 

if not Started [ User ] then begin 

Started ( User ] := true; 

NJBuf := StackPtrs [ User ]; 

inline( $8B/ $26/ NJBuf); { MOV SP,[NJBuf] } 

NJBuf := StacfcSegs [ User ]; 

inline( $A1/ NJBuf/ { MOV AX,[NJBuf] } 

$8E/ $D0); ( M0V SS,AX } 

EnterMainProcess; 
end else begin 

NJBuf := StackPtrs [ User ] ; 

inline( $8B/ $2E/ NJBuf); ( MOV BP,[NJBuf] } 

NJBuf := StackSegs [ User ] ; 

inline( $A1/ NJBuf/ ( MOV AX,[NJBuf] } • 

$8E/ $D0); { M0V SS,AX } 

end; 

end; 

procedurę NextJob; 
begin 

if Clock o LastClock then begin 

LastClock := Clock; NextJobl; 
end; 
end; 

procedure BaudRate(Baud : Integer); 
var Adr : Word; 

i : Integer; 

procedurę SetDiv(H,L ; Integer); 
begin 

Port[Adr] := L; Port[Adr+l] := H; 

end; 
begin 

for i := 1 to MaxActiveUser do begin 

Adr := Address [i]; 

Port[Adr+3] := Port[Adr+3] or $83; 
case Baud of 

600 : SetDiv(0,$C0); 

1 200 SetDiv (0, $60) ; 

2400 : SetDiv(0,$30); 

4800 : SetDiv(0,$18); 

9600 : SetDiv(0,$0C); 

19200 : SetDiv(0,$06); 
end; 

Port[Adr+3] := Port[Adr+3] and $7f or $03; 
Port(Adr*4] := $03; 
end; 
end; 

procedurę SendChar(Ch ; Char); 
var Adr ; Word; 
begin 

Adr := Address [User]; 

repeat until Port[Adr+5] and $60 = $60; 

Port[Adr]:=Ord(Ch); 
end; 

function CharReady(Usr : Users) : Boolean; 
var Adr : Integer; 
begin 

Adr ;= Address [ Usr ]; 

CharReady := {Port[Adr-.-5] and $01 o 0); 
end; 

functfon ReadChar{Usr:Integer) : Char; 
var Adr : Integer; 
begin 

Adr := Address [ Usr ]; 

while Port[Adr+5] and $01 = 0 do; 

ReadChar := Chr(Port[Adr]); 
end; 

procedurę SendString(A : Alpha); 
var I : Integer; 

V -> 

« 
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begin 

for i := 1 to Length(A) do SendChar(A[i]); 
end; 

procedurę PutQueue(Ch : Char; Usr : Integer); 
begin 

with Queue [ Usr ] do 

if QueueLen < QueueLength then begin 

QueueLen := QueueLen + 1; 

Buf [ QueueEnd ] := Ch; 

QueueEnd := (QueueEnd + 1) mod QueueLength; 
end; 

end ; 

function GetQueue : Char; 
begin 

with Queue [ User ] do begin 

GetQueue Buf [ QueueStart ]; 

QueueLen := QueueLen - 1; 

QueueStart ;= (QueueStart + 1) mod QueueLength; 
end; 
end; 

procedurę Scaninput; 
begin 

if Crt.KeyPressed then PutQuęue(Crt.ReadKey,0); 
end; 

procedurę ScanRS232; 
var Usr : Integer; 
begin 

for Usr ;= 1 to MaxActiveUser do’ 

if CharReady(Usr) then PutQueue(ReadChar(Usr),Usr) 

end; 

procedurę Clockinterrupt; interrupt; 
begin 

ScanRS232; 

Clock ;= Clock + 1; 
end; 

procedurę ClockInterruptsOn; 
begin 

GetIntVec(Clockint,OldClockPtr); 

SetIntVec(Clockint,Addr(Clockinterrupt)); 
end; 

procedurę ClockInterruptsOff; 
begin 

SetIntVec(Clockint,OldClockPtr); 
end; 

function KeyPressed ; Boolean; 
begin 

KeyPressed := (Queue[User].QueueLen > 0); 
end; 

function ReadKey : Char; 
begin 

repeat NextJobl until KeyPressed; 

ReadKey := GetQueue; 
end; 

procedurę GotoXY(X,Y : Integer); 
begin 

if Master then Crt.GotoXY(X,Y) 

else SendString(ESC+'Y'+Chr(Y+31)+Chr(X+31)); 

end; 

procedurę ClrScr; 
begin 

if Master then Crt.ClrScr 

else SendString(ESC+'E'+ESC+'H'); 

end; 

procedurę ClrEol; 
begin 

if Master then Crt.ClrEol 

else SendString(ESC+'K'); 

end; 

procedurę TrueYideo; 
begin 

if Master then begin 

TextColor(LightGray) ; 

TextBackground(Black); 
end 

else SendString(ESC+’q'); 

end; 

procedurę InvVideo; 
begin 

if Master then begin 

TextColor(Black); 

TextBackground(LightGray); 
end 

else SendString(ESC+'p'); 

end; 

procedurę InsLine; 
begin 

if Master then Crt.Insline 

else SendString (ESC**-' L') ; 

end; 

procedurę DelLine; 
begin 

if Master then Crt.DelLine 

else SendString(ESC+'M*); 

end; 

procedurę OutputChar(Ch : Char); 

var ConOutPtrLocl, Con0utPtrLoc2 ; Pointer; 
begin 

if Master then 

with TextRec(Output) do begin 

ConOutPtrLocl' := InOutFunc; 

InOutFunc := TConOutPtr; 

ConOutPtrLoc2 := FlushFunc; 

L. .. > 
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■pozostałych użytkowników.'); 

GotoXY(24,13); 

Write(’By wznowić zadanie - wcisni] ESC.'); 
end; 

GotoXY(79,24); 
end; 

begin 

InitMainProcess; 
end. 

unit UserProc; 

interface 

uses MProcLib; 
procedurę UserProcedure; 

implementation 

function GetString(MaxLen : Integer) : String; 
var Ch ; Char; 

S : string; 
begin 

S : = " ; 
repeat 

Ch := ReadKey; 
if Ch o 'M then 
case Ch of 

"H : if S <> '' then begin 

S := Copy(S,1,Length(S)- 1 ) ; 

Write(~H' '“H); 
end; 

else if Length(S) < MaxLen then begin 
S := S > Ch; 

Write(Ch); 
end; 

end; 

until Ch = ~M; 

GetString := S; 
end; 

procedurę UserProcedure; 

Char ; 

In teger ; 

String; 

Pointer; 

Text; 

procedurę WriteS(S : String); 
var 1 : Integer; 

begin for i.:= l to Length(S) do Write(S(iJ); 
end ; 

begin 
ClrScr; 
repeat 
Writeln; 

Writeln('Program przykładowy (proces nr ',User,')'); 
Writełn(' 1) Pisz łosowy tekst'); 

2) Wczytaj tekst'); 

3) Wyczysc ekran’); 

4) Wołna pamięć'); 

5) Pokaz płik tekstowy'); 

0) Koniec'); 

Writełn('Twój wybór ?'); 

repeat Ch := ReadKey untił Ch in ('0' 
case Ch of 
'1' : repeat 

for 1 := 1 to 77 do Write(Chr(Random(26)♦65)) ; 
Writełn; 

untił KeyPressed; 
begin 

Writełn; WriteCPoda] tekst: '); 

S := GetString(65); 

Writełn; Wri te ('To był tekst.- '); 

InWideo; WriteS(S); TrueYideo; 

Writełn; 
end; 

CłrScr; 
begin 

if MemAvaił >= 10000 then begin 
GetMem(P,10000); 

FiłłChar(P",10000,0); 

FreeMem(P,10000); 
end; 

Writełn('MemAvaił = ',MemAvaił); 
end; 
begin 

Writełn; Write('Podaj nazwę płiku: ' 

S := GetString(40); Writełn; 
if S <> '' then begin 

Assign(F,S); {$!-) Reset(F); ($I>) 
if lOResułt = 0 then begin 
whiłe not Eof(F) do begin 
Read(F,Ch); Write(Ch); 
end; 

Cłose(F); 
end ełse 

Writełn('Płik 

end; 
end; 

end; 

untił Ch = '0'; 
end ; 
end. 


Writełn( 
Writełn( 
Writełn( 
Writełn( 
Writełn( 


5 ' ]; 
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+S+' nie istnieje') 


obsługi kanału Output. Kanał Input nie wymaga modyfikacji, po¬ 
nieważ nie może być on używany w proponowanym rozwiązaniu. 
Wszelkie operacje współpracy z klawiaturą należy wykonywać za 
pomocą własnych procedur odwołujących się do funkcji Read¬ 
Key. Nie stanowi to jednak w praktyce żadnego ograniczenia. De¬ 
finiowanie obsługi kanału Output wykorzystuje oferowane przez 
kompilator Turbo Pascal 4.0 mechanizmy obsługi plików teksto¬ 
wych (text device dńvers). 

Każda z nowych procedur ekranowych posiada podobną budo¬ 
wę: jeśli realizujący się w danym momencie proces związany jest z 
komputerem macierzystym, to wywoływana jest analogiczna pro- 
cediura ze standardowej biblioteki Crt; w przeciwnym wypadku do 
kanału szeregowego przyporządkowanego do tego procesu, wy¬ 
syłana jest odpowiedma sekwencja znaków sterujących. W przed¬ 
stawionym programie przykładowym zostały zastosowane kody 
standardu VT-52. Oczywiście można je zmienić lub wbudować me¬ 
chanizmy wyboru rodzaju stosowanych terminali. 

Przedstawiony obok tekst programu składa się z trzech części: 
modułu MProcLib, zawierającego niezbędne funkcje i procedury, 
modułu UserProc, zawierającego użytkową część programu (pro¬ 
cedura UserProcedure) oraz programu głównego MP, odwołują¬ 
cego się do obu powyższych modułów. W module MProcLib 
o^eślone są m.in. takie parametry, jak maksymalna liczba proce¬ 
sów (MaxUser), głębokość stosów procesów związanych z termi¬ 
nalami (StackDepth) oraz długość kolejki znaków czytanych z łą¬ 
czy szeregowych (QueueLength). W module tym znajdują się tak¬ 
że zmienne User (numer aktualnego procesu). Master (o wartości 
True, gdy User = 0), MaxActiveUser (maksymalny numer proce¬ 
su), procediuT^ NextJob i NextJobl, procedury InvVideo i TrueYi¬ 
deo do włączania i wyłączama inwersji obrazu oraz wszystkie pro¬ 
cedury i funkcje, które wymagały redefinicji. Moduł ten dokonuje 
również alokacji obszarów stosów i danych oraz modyfikacji kana¬ 
łu Output. Moduł UserProc zawiera niewielki program przykłado¬ 
wy ilustrujący sposób komunikacji z klawiaturą i ekranem. Do pro¬ 
gramu MP można przekazać dwa parametry: pierwszym jest liczba 
procesów (terminali) organizowanych w fazie inicjacji, drugim — 
szybkość transmisji szeregowej w bodach. 

Podstawową ideą proponowanego rozwiązania jest to, że sposób 
pisania wielodostępnego programu w Pascalu niewiele różni się 
od zwykłego. Standardowe procedury ekranowe i obsługi klawia¬ 
tury działają poprawnie niezałeżnie od rodzaju aktuałnie realizowa¬ 
nego procesu. Umożliwia to stosunkowo łatwe dostosowanie ist¬ 
niejących programów do postaci wielodostępnej. Istnieje tylko kil¬ 
ka formalnych wymogów: 

• w tekście programu należy w wybranych miejscach umieszczać 
wywołania procedury NextJob - tak, aby zachować częste prze¬ 
łączanie procesów niezależnie od aktualnie wykonującego się 
fragmentu programu; 

• wszelkie operacje współpracy z klawiaturą należy dokonywać 
poprzez procedurę ReadKey, nie należy używać kanału Input; 

• do gospodarki pamięcią dynamiczną należy używać procedur 
New, Dispose, GetMem i FreeMem, nie należy natomiast sto¬ 
sować Mark i Release (funkcje MemAYail i MaxAvail działa¬ 
ją poprawnie); 

• nie należy modyfikować zmiennych opisujących stan proce¬ 
sów, w tym zmiennych User, Master i MaxActiveUser; te osta¬ 
tnie można oczywiście czytać w celu wprowadzenia mechaniz¬ 
mów działających zależnie od numeru procesu (np. zezwolenia 
dla operatorów na dostęp do bazy danych lub drukarki). 

Poza tym jedną z najważniejszych cech rozwiązania jest fakt, że 

zmiana procesu dokonywana jest tylko w niektórych, przez nas wy¬ 
branych, miejscach programu. Eliminuje to praktycznie wszystkie 
problemy związane z zachowaniem bezpiecznego dostępu do 
wspólnej bazy danych. 

Przedstawiony tekst programu zawiera tylko niezbędne mecha¬ 
nizmy konieczne dla zaprezentowania metody. Brak jest m.in. pro¬ 
cedur dostępu do wspólnej drukarki oraz systemu plików bazy da¬ 
nych. Są to jednak problemy, które już łatwo może rozwiązać każdy 
zainteresowany (wykorzystując np. DataBase Tool Box firmy Bor¬ 
land). 

Przedstawione rozwiązanie może służyć do stworzenia wielodo¬ 
stępnego programu (np. typu baza danych), o bardzo niewielkich 
wymaganiach sprzętowych. Szczególnie nadaje się do realizacji 
programu do równoległego wprowadzania i wyszukiwania infor¬ 
macji. Dla takich zadań możliwe jest używanie do 8 terminali z kom¬ 
puterem AT lub do 4 z komputerem o pamięci operacyjnej 256 KB. 
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Wskaźniki 

w Pascalu [1] 


Wskaźniki i rekordy z wariantami stanowią rekurencyj- 
ne struktury danych w Pascalu. Charakterystyczną ich ce¬ 
chą jest możliwość zmieniania rozmiarów — każda ze skła¬ 
dowych struktury ma przydzielaną pamięć w chwili powo¬ 
łania do życia podczas wykonywania programu, a nie pod¬ 
czas kompilacji. W przypadku struktur podstawowych (ta¬ 
blice, rekordy) rozmiar przydzielonej pamięci, a co za tym 
idzie zakres wartości przyjmowanych przez zmienne o tej 
strukturze jest określony raz na zawsze w chwili definiowa¬ 
nia typu. Chciałbym przedstawić struktury wskaźnikowe - 
wygodne i popularne narzędzie programisty. 

Na wstępie chciałbym przestrzec przed nadużywaniem tych struk¬ 
tur — wykorzystują one dużo pamięci i dlatego np. do wspomagama 
obliczeń numerycznych zalecałbym stosować tablice. Z kolei wskaź¬ 
nikowa struktura danych znajduje zastosowanie w ciekawym proce¬ 
sie sortowania topologicznego. Jest to proces sortowania danych na 
podstawie zdefiniowanego porządku częściowego - porządku okre¬ 
ślonego dla niektórych par danych. Przykładowo w prograime zajęć 
uniwersyteckich ze względu na układ materiału pewne zajęcia muszą 
odbyć się przed innymi. Topologiczne sortowanie polega na takim 
ułożeniu programu, aby zajęcia wcześniejsze nie odwoływały się do 
materiału z zajęć późniejszych (problem sortowania topologicznego 
został szczegółowo opracowany w książce Niklausa Wirtha ”Algoryt¬ 
my + struktury danych = programy”). 

W strukturach wskaźnikowych v^óżniamy obiekty dwóch typów: 

- wskazywnego (rekordy, tablice, pliki, które są przedmiotem 
wskazań), 

— wskazującego ( do wskazywania elementów typu wskazywane¬ 
go). 

Popatrzmy na ciąg deklaracji: 

type wskaźhLk = ^kostka; 
kostka = record 

wartość; integer; 
strzałka: wskaźnik 
end; 

var pierwszy, kolejny : wskaźnik; 


Typ wskazujący - "wskaźnik” jest typem prostym, ale nie należy go 



ty typu "kostka”. Pole "strzałka” służy do komunikowania się z innymi 
elementami typu. Do operacji na stiukturach wskaźnikowych służą 
procedury new() i disposeO, których argumentami są zmienne typu 


wskazującego - w naszym przypadku typu "wskaźnik”. Procedura 
new() tworzy dynamicznie (w trakcie wykonywania programu) ele¬ 
ment typu wskazywanego, czyli rekord typu "kostka”, zaś procedura 
disposeO przypisuje zmiennej wskazanie nieokreślone i zwalnia miejs¬ 
ce w pamięci po obiekcie wskazania (należy ostrożnie posługiwać się 
tą procedurą). Powołajmy do życia prostą strukturę wskaźnikową: 
new( pierwszy ); 
pierwszy-wsirtość := 12; 
pierwszy strzałka := nil; 

Wywołanie procedury new() utworzyło rekord wskazywany przez 
zmienną "pierwszy", dostęp do pól tego rekordu następuje właśnie 
przez tę zmienną: 

- pierwszy^ wskazuje nam nowo utworzony rekord, 

- pierwszy'^ .wartość lub pierwszy'^ .strzałka precyzuje pole, do 
którego będziemy się odwoływać. 

Polu "strzałka” można przypisać wskazanie puste - nil, lub utworzyć 
nowy rekord, który będzie ono wskazywać. Jak łatwo zauważyć, mo¬ 
żna w ten sposób utworzyć listę rekordów, powiązanych wskazania¬ 
mi przez pole "strzałka”. Tego typu listy naz^ają się w literaturze li¬ 
stami prostymi lub liniowymi. Przedstawię kilka użytecznych proce¬ 
dur do posługiwania się listami. Zacznijmy od tworzenia listy - bę¬ 
dziemy czytać wartości z klawiatury i wpisywać do listy. Plik "input” 
należy skojarzyć z klawiaturą (konsolą): 

procedurę czytanie( var początek : wskaźnik); 

var następny: wskaźnik; 
begin 

if not eof( input) then 
begin 

new( początek); 
następny: = początek; 
read( następny'" .wartość) 
while not eof( input) do 
begin 

new( następny'".strzałka); 
następny := następny'" .strzałka; 
read( następny'".wartość) 

end; 

następny'" .strzałka := nil 
end 
else 

początek :=nil 

end; 

Procedura zwraca puste wskazanie zmiennej "początek”, kiedy nie 
ma danych, lub wskazanie na listę rekordów zawierających dane. Do 
poruszania się po liście służą przypisania: 
następny: = początek;, 
następny := następny'".strzałka; 

Pierwsze z nich jest oczywiste: zmienne "początek" i "następny” 
wskazywać będą ten sam rekord. Drugie kryje w sobie całą tajemni¬ 
cę popularności list. Wyobraźmy sobie, że zmienna "następny” znaj¬ 
duje się nad listą rekordów i wskazuje jeden z nich. Rekordy są oczy¬ 
wiście połączone ukierunkowanymi strzałkami. Przypisanie "następ¬ 
ny := następny'" .strzałka” popycha zmienną "następny” do przodu - 
wskazywać będzie kolejny rekord z listy. W ten sposób można listę 
łatwo tworzyć i przeszukiwać (bez tasiemcowych odwołań, jak np. 
początek'".strzałka'".strzałka'" .wartość itp.). Warto nadmienić, że 
same wskaźniki mogą być argumentami relacji ” = ” i ” <> ”. 

Za miesiąc przedstawię kilka innych użytecznych procedur i przy¬ 
kładów zastosowania list. Zainteresowanym polecam lekturę książek 
pana Niklausa Wirtha. 

(MJ) 
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Wirusy chronią, przed wirusami 

Programy kopiuję.ce się samoczynnie i zagmeżdżajęce się w in¬ 
nych programach nazywane są programami wirusowymi. Rozprze¬ 
strzeniając się podobnie jak wirusy organiczne w żywych ciałach, 
stanowią olbrzymie zagrożenie dla systemów komputerowych. Po 
ostatnich spektakularnych wydarzeniach - choćby włamaniu do 
ogólnoświatowej sieci NASA, problem wirusów komputerov\^ch 
dotarł wreszcie do świadomości użytkowników komputerów jako 
groźne zjawisko. W konsekwencji wzmożone działania w celu zna¬ 
lezienia skutecznych środków zaradczych. Poszukuje się metod 
wszechstronnego zabezpieczenia, które nie ogramczałyby możli¬ 
wości użytkowych systemu, a ponadto gwarantowały automatycz¬ 
ną ochronę przed wirusami. Ten ostatni element jest niezwykle wa¬ 
żny, jako że wielu użytkowników często ze zwykłego wygoctoctwa 
zaniedbuje przestrzegania rutynowych środków ostrożności. Po¬ 
dobnie jak wirusy organiczne, programy wirusowe zdolne są do 
przeobrażania się (mutacji) w celu wymknięcia się mechanizmom 
obrormym organizmu. Nie wszystkie jednak programy mogą się 
stać "żywicielami” wirusów. Rzeczywista ewolucja podobna do wy¬ 
stępującej w przyrodzie jest niemożliwa, ponieważ wirus kompute¬ 
rowy może się sam modyfikować tylko w ramach nakreślonych 
przez jego twórcę. Wirusy mogą wprawdzie przy sprzyjających 
warunkach przechodzić mutacje przez wiele generacji, jedn^ 
przez podjęcie drastycznych środków możliwe jest pozbawienie 
ich podstawy egzystencji. Tak jak wirusy organiczne skazane są na 
zagładę z chwilą śmierci ich żywiciela, tak możliwe jest pozbycie 
się wirusów komputerowych przez radykalną kurację, polegającą 
na całkowitym wyczyszczeniu i skonfigurowamu na nowo systemu. 
W razie potrzeby odbywa się to przez "sterylizację” "przestrzeni 
życiowej” wirusów, co w przypadku komputera oznacza wykaso¬ 
wanie wszystkich programów. Aby przetrwać, żywe organizmy 
musiały w toku ewolucji rozwinąć mechanizmy obronne przeciw 
infekcjom wirusowym. W ciałach osobników wyżej zorganizowa¬ 
nych bronią przeciwko wirusom są występujące we krwi przeciw¬ 
ciała, które posiadają zdolność wykrywania i niszczenia obcych or¬ 
ganizmowi komórek. Fakt, że programy wirusowe imitują cechy i 
strategie działemia organicznych wirusów, podsunął pomysł stwo¬ 
rzenia programów naśladujących działanie przeciwciał. Programy 
takie powinny działać samodzielnie i być niezauważalne dla użyt¬ 
kownika podczas normalnej pracy. 

Przy tych założeniach nowa koncepcja programów zwalczają¬ 
cych wirusy polega na wykorzystaniu strategii działania programu 
wirusowego, który zostaje zmieniony tak, aby wyszukiwał i imiesz- 
kodliwiał inne wirusy. Programy tego typu nazywane są w oparciu 
o analogie biologiczne przeciwciałami. Jednak rówmeż tutaj poja¬ 
wiają się ograniczenia dla programu i sposobu jego funkcjonowa¬ 
nia, wynikające z "przestrzeni życiowej” komputera. Przeciwcia 
organiczne po prostu pożerają wykryte przez siebe obce ciału ko¬ 
mórki. W przeciwieństwie do żywego organizmu komputer nie ma 
istotnego elementu ochrony, jaką są indywidualne cechy osobni¬ 
cze, pozwalalające bezbłędnie określić to, co jest ciałem obcym. 
Dla komputera wirus jest programem, który traktuje jak każdy 
inny, to znaczy po prostu go wykonuje. Wobec tego jedyną możli¬ 
wością jest przeanalizowanie danego programu w stame pełnego 
"zdrowia” jako "osobnika” i traktowanie każdego późniejszego od- 
w‘ :>pstwa od wzoru jako "ciała obcego”. Programowe przeciwciała 


nie powinny przy tym stosować "brutalnych” metod, to znaczy np. 
usuwania zaatakowanego pliku po wykryciu wirusa, lecz ograni¬ 
czanie się do zgłaszania użytkownikowi nielegalnych operacji na 
zbiorach. Aby wirusowe przeciwciało mogło skutecznie działać, 
należy najpierw określić sposób działania wirusa, który ma zwal¬ 
czać. 

Programy wirusowe można podzielić na trzy grupy: 

• Wirusy pierwszego typu najbardziej podobne są do swych bio¬ 
logicznych krewnych. Niszczą program oryginalny poprzez za¬ 
pisanie na nim swojego własnego kodu. Od tego momentu jedy¬ 
ną funkcją, jaką spełnia zaatakowany program staje się produ¬ 
kowanie nowych wirusów. Następuje to przy każdej próbie jego 
uruchomienia, przy czym dla kamuflażu wyświetlany jest komu¬ 
nikat informujący o wystąpieniu jakiegoś błędu. Ten gatimek 
wirusów daje się zatem stosunkowo łatwo wykryć. 

• Wirusy drugiego typu utrzymują program oryginalny w st^e 
umożliwiającym jego uruchomienie i kopiują się na jego końcu. 
Na początloi programu dopisywany jest bajt identyfikacyjny, in¬ 
formujący o tym, że program jest już zakażony. Te wirusy mogą 
bez wiedzy użytkownika zainfekować wszystkie program.y 
komputera. Dają one o sobie znać dopiero w momencie, gdy 
zajmą się czymś innym niż samoczynne rozmnażame, np. syste¬ 
matycznym niszczeniem danych lub programów. 

• Najbardziej zaawansowane i przez to najtrudmejsze do wykry¬ 
cia są wirusy trzeciego typu. Nie zmieniają one początku pro¬ 
gramu, lecz modyfikują jakiś punkt wewnątrz kodu, aby stamtąd 
odsyłać do odpowiednich procedur. Moment, w któryrn to na¬ 
stępuje jest różny w poszczególnych programach. Możliwe jest 
tu wplecenie najróżniejszych zadań dodatkowych. 

Przeciwciała programowe mają rozmaite możliwości wykrywa¬ 
nia zakażonych programów. Warunkiem dla każdej metody poró¬ 
wnawczej jest istnienie niezakażonej (oryginalnej) wersji progra¬ 
mu. Programy wirusobójcze tzw. ”vinis-idZ/er”dziiająinaczej, mia¬ 
nowicie poszukują już znanych wirusów. Ich wadą jest to, że znajdu¬ 
ją one tylko konkretne typy wirusów, natomiast są bezradne wobec 
wirusów przechodzących mutacje. Ponadto dają się one łatwo 
oszukać przez wirusy, których programiści dokonują niewielkich 
zmian w programach, na które "killer” nie reaguje. Największym 
niebezpieczeństwem takich "wirusobójców” jest to, iż dają złudną 
pewność. Zgłaszają one, że system jest wolny od wirusów, podczas 
gdy w rzeczywistości stwierdziły jedynie nieobecność kilku nieli¬ 
cznych ich odmian. Wobec matematycznie dowiedzionej niemoż¬ 
ności odróżnienia programu wirusowego od niewirusowego, jedy¬ 
ną możliwością identyfikacji pozostaje bezpośrednie poróv^aiue. 
Stąd strategia działania przeciwciał oparta jest na założeniu, że każ¬ 
dy program wirusowy musi przy infekowaniu zmienić kod progra¬ 
mu, który zaatakował. Zmiana ta może być minimalna i dobrze 
ukiyta (niezmieniona długość programu!). Celem działama przeci¬ 
wciała jest wykrycie wszelkich odstępstw od wzorca i poinformo¬ 
wanie o tym użytkownika. Bezpośrednie porówname programu 
oryginalnego z kopią roboczą, dokonywane przez niektóre pro¬ 
gramy "wiruso ochronne” jest łatwe do zrobienia. Porównuje się je¬ 
dynie wielkość programu, do ostatniej cyfry, z wielkością progra¬ 
mu oryginalnego. Metoda ta ma jednak istotne wady. Jest czaso¬ 
chłonna, bo programy oryginalne nie mogą być zapisywane do pa¬ 
mięci komputera. W wielu przypadkach można do nich dotrzeć tyl¬ 
ko poprzez dyskietki. Ponieważ dla zapewnienia koniecznego bez¬ 
pieczeństwa porównanie należałoby przeprowadzić przed każ¬ 
dym uruchomieniem programu, jest ono w praktyce niemożliwe. 
Ponadto także interpreter rozkazów (COMMAND.COM) musiałby 
zostać przetestowany, aby wykluczyć ewentualne manipulacje ka¬ 
talogiem przez wirus. Problem ten da się obejść przez zastosowa¬ 
nie przeciwciała pracującego wg strategii wirusa. Ze względu na 
zasadę działania przeciwciało jest wirusem, który automatycznie 
się roznmaża i samodzielnie chroni wszystkie programy. Użytkow¬ 
nik nie zauważa działania przeciwciała do momentu, gdy wykryje 
ono wirus. 

Istnieją dwie metody sprawdzania programu. Pierwsza polega 
na obliczaniu sum kontrolnych, które dołączane są do końca pro¬ 
gramu jako dane i według nich można stwierdzić zmiany. Wadą tej 
metody jest znaczne przedłużenie kodu programowego. W konse¬ 
kwencji może dojść do tego, że obszerne programy nie będą się 
mieściły w pamięci komputera lub na dyskietce. Niewątpliwą zale¬ 
tą jest natomiast możliwość stwierdzenia zmian jeszcze przed star¬ 
tem właściwego programu. 

Druga metoda polega na nadaniu programowi cech indywidual¬ 
nych, poprzez zaszyfrowanie jego kodu. W przypadku, gdy wirus 
zaatakuje tak chroniony program, po rozszyfrowaniu (starci^ro- 
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gramu) powstaje automatycznie błąd, prowadzący zwykle do zała¬ 
mania systemu. Na korzyść tej metody przemawia fakt, iż nie zabie¬ 
ra dodatkowo pamięci. Wadą z kolei jest to, że następstwa działa¬ 
nia przeciwciała nie dają się ani przewidzieć, ani przeanalizować. 
Przy niesprzyjających okolicznościach błąd może leżeć w rzadko 
używanej części programu (i dlatego późno daje o sobie znać), lub 
nie powoduje załamania systemu, a w zamian za to niszczy dane na 
dysku lub dyskietce. Do tego dochodzi fakt, że za powstanie błędu 
odpowiedzialne mogą być inne usterki sprzętowe lub programo¬ 
we. 

Duże niebezpieczeństwo stanowi wirusowy charakter przeciw¬ 
ciała programowego. Stosowanie wszelkich wirusów zawsze zwią¬ 
zane jest z ryzykiem. W systemach dużych komputerów nie sposób 
przewidzieć działania przeciwciała na różnych płaszczyznach do¬ 
stępu, gdzie nie dają się one kontrolować, nie mówiąc już o prześle¬ 
dzeniu ich funkcjonowania. A więc: jeśli już ochrona przed wirusa¬ 
mi za pomocą przeciwciał, to najlepiej jest stosować programy na¬ 
pisane samemu lub pochodzące z pewnych źródeł! 

Przeciwciało powinno być zbudowane w sposób następujący: 
Po wywołaniu dowolnego programu, powinien pojawić się komu¬ 
nikat informujący o aktywności przeciwciała. Jeśli taki meldimek 
me następuje, użytkownik może przypuszczać, że nastąpiło zaka¬ 
żenie winisem pierwszego typu i przeciwciało zostało skasowane. 
Następnie sprawdzane są sumy kontrolne a wynik testu podawany 
jest użytkownikowi. W przypadku wykrycia błędów przy porów¬ 
naniu, zatrzymane zostaje wykonanie programu i pojawia się 
ostrzeżenie. Przy błędzie w sumie kontrolnej przyczyną może być 
infekcja wirusami drugiego lub trzeciego typu. Jeśli kontrola prze¬ 
biega prawidłowo, przeciwciało rozpoczyna poszukiwanie nie- 
chronionych programów. Gdy nie znajdzie żadnego, samoczynnie 
się kasuje i zwalnia pamięć dla programu głównego. Jeśli znajdzie 
niechroniony program, zgłasza ten fakt na ekranie i pyta, czy wska¬ 
zany program ma być chroniony. Jeśli tak, wylicza sumy kontrolne 
i dopisuje się do kodu programowego. Konwersacja z użytkowni¬ 
kiem jest bardzo ważna, jako że umożliwia zapobieganie niekon¬ 
trolowanemu rozprzestrzenianiu się programu, jakby nie było wi¬ 
rusa. Jako dodatkowe zabezpieczenie można założyć na dyskietce 
protokół, w którym odnotowywane byłyby wszystkie zabezpieczo¬ 
ne programy, włącznie z datą zabe^ieczenia i ewentualnie z suma¬ 
mi kontrolnymi. Pytanie użytkownika o to, czy program ma zostać 
zabezpieczony, jest konieczne, by zapobiec manipulacjom na pro¬ 
gramach posiadających ochronę przed kopiowaniem. Wszelkie 
próby zmian w ich kodzie mogłyby spowodować zakłócenia w ich 
funkc j ono waniu. 

Przyszły rozwój wirusów i przeciwciał jest jeszcze sprawą otwar¬ 
tą. Przy istniejących systemach operacyjnych niebezpieczeństwo 
wirusowe będzie można zmniejszyć, ale nie da się ono nigdy całko- 
vwcie wyeliminować. W lokalnie uż^kowanych komputerach oso¬ 
bistych ryzyko wirusowe daje się znacznie zmniejszyć już przez za- 
stosowame konwencjonalnych środków. Na poziomie sprzętowym 
zarysowują się koncepcje, które utrudnią życie wirusom w kompu¬ 
terach osobistych. Dalszy rozwój techniki CD-WORM (Write Once, 
Read Many= jednorazowy zapis, wielokrotny odczyt) sprawi, że 
nośniki danych i programów będą utrzymywane oddzielnie, a pro¬ 
gramy będą się wprawdzie dawały kopiować, ale nie da się na nich 
nic zapisywać. 

Problem wirusów w dużych systemach komputerowych będzie 
istni^ jeszcze długo. Komputery pracujące w coraz rozleglej szych 
sieciach nie dadzą się przebudować po prostu z dnia na dzień. Aby 
utrz^^ać zgodność systemów konieczne byłoby zorganizowanie 
akcji na skalę światową, przeprowadzonej synchronicznie o ozna¬ 
czonej godzinie zero. Także z prawnego punktu widzenia stosowa¬ 
nie przeciwciał jest na razie problematyczne. Dopóki użytkownik 
pracuje na wyizolowanej maszynie, na własnych programach, któ¬ 
re do tego jeszcze sam napisał, nie ma problemu. Inaczej sprawa 
wygląda w przypadku pracy w sieciach korzystających z licencjo¬ 
nowanych programów. Tu zastostowanie przeciwciał byłoby łama¬ 
niem prawa, ponieważ licencje nie zezwalają na modyfikacje uży¬ 
wanych programów. 


Sposób 


programów wirusowych 


Oryginalny program przed infekcją 


Program XYZ 


Po zainfekowaniu przez wirus typu I: 


Wirus zapisuje program oryginalny. Program zostaje zniszczony i 
nie daje się uruchomić. 

Po zainfekowaniu przez wirus typu II: 


Wirus kopiuje bajty rozpoznawcze ”K” na początek programu. ”K” 
uruchamia część ”wirus” na końcu programu. Zaatakowany pro¬ 
gram daje się zwykle uruchomić, problemy występują najczęściej 
przy programach zabezpieczonych przed kopiowaniem. 

Po zainfekowaniu przez wirus typu III: 


Prgl 

K 

prg2 

Wirus 

Data 


Wirus kopiuje część programu do zbioru danych "DATA” i dzieli 
program na obszary ”prg 1” i ”prg 2”. W określonym miejscu pro¬ 
gramu umieszcza instrukcję skoku (”K”) do zasadniczego progra¬ 
mu wirusowego. Po jego wykonaniu obszar danych jest przepisy¬ 
wany z powrotem na swoje miejsce, a program wirusowy jest kaso¬ 
wany z pamięci. W ten sposób program oryginalny daje się prawie 
zawsze uruchomić, a odnalezienie wirusa jest bardzo trudne, bo¬ 
wiem sam usuwa się z pamięci. 

Sposób działania wirusowego przeciwciała 


Program oryginalny: Program XYZ 


Program po zabezpieczeniu przez wirusowe przeciwciało: 


K 

Program XYZ 

wp 

data 


Znacznik ”K” powoduje, że program identyfikowany jest jako już 
zakażony i wywołuje przed wykonamem zasadniczego programu 
procedurę ”wp”, która sprawdza program na podstawie zapisa¬ 
nych w zbiorze "data” sum kontrolnych. 


Budowa przeciwciała: 


Komunikat informujący o rozpoczęciu działania przez program 


Poszukiwanie zbiorów programowych 


Sprawdzenie bajtu identyfikacyjnego (K) 

ISTNIEJE 

NIE ISTNIEJE 


Pytanie zwrotne (zabezpieczyć?) 

TAK 

NIE 


Dopisać na początku programu 
bajt rozpoznawczy. 



Dopisać do końca programu 
kod wirusowego przeciwciała 



Wyliczyć sumy kontrolne, zapisać je 
w zbiorze danych na końcu programu. 




Początek sprawdzania własnego programu: 


Sprawdzić bajt rozpoznawczy na początku programu. 

Porównać sumy kontrolne ze zbioru danych z program em. 

Błąd~ Brak błędów 


Podać komunikat o błędzie, 

przerwać wykonywanie 
programu. 


Brak błędów 


Usunąć przeciwciało z pamięci, 

Uruchomić program. 


Wirus Reszta 


GARSC PRZYKŁADÓW 

Użytkownicy komputerów nie są zupełnie bezbronni przed ata¬ 
kiem wirusów. Kilka firm produkujących oprogramowanie oferuje 
już programy ochronne, działające według różnych strategii. 

Chociaż jak dotąd niebezpieczeństwo wirusowe dla kompute¬ 
rów pracujących w systemie MS-DOS nie przybrało jeszcze tak 
dramatycznych rozmiarów, jak w przypadku systemów średniej 
wielkości, czy też dużych maszyn połączonych w sieci, na rynku za¬ 
chodnim pojawiło się szereg programów reklamowanych jako ”vi- 
rus-kiUer” (programy wirusobójcze). Pracują one według różnych 
koncepcji i różnią się znacznie ceną. 

”Disk Watcher” firmy RG Software jest rozwinięciem progra- 
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Pakiety zintegrowane 


mu o tej samej nazwie, istniejącego już od dłuższego czasu. Jest 
on przydatnym programem narzędziowym, a począwszy od we¬ 
rsji 2.0 oferuje także ochronę przed programami wirusowymi. 
Będąc z założenia wyławiaczem błędów, posiada funkcje na¬ 
dzorujące pracę stacji dysków elastycznych i twardych. Rozwi¬ 
nięcie tych funkcji czyni z ”Disk Watcher” całkiem przydatny 
program, rozpoznający obecność wirusów w komputerze przed 
rozpoczęciem przez nie niszczycielskiej działalności. ”Disk 
Watcher” próbuje rozpoznać wirusy na podstawie ich zacho¬ 
wania. Po uruchomieniu program sprawdza, czy w pamięci ope¬ 
racyjnej lub na dyskach znajdują się "podejrzane” programy. Za 
podejrzane cechy ”Disk Watcher” uważa manipulowanie pro¬ 
gramami, kasowanie dużej ilości danych oraz kopiowanie pro¬ 
gramu lub innego pliku na jakiś już istniejący. Sprawdzane jest 
zastosowanie przerwań BIOS- u (5, 9, 13, 17, IC, 20, 21, 22 i 26). 
Podczas testu z wirusem DEMO ”Disk Watcher” wydał jedno¬ 
cześnie dwa komunikaty ostrzegawcze. Informowały one o nie¬ 
typowym działaniu programu i nakazywały użytkownikowi wy¬ 
bór między zakończeniem, a kontynuacją operacji na plikach. 
Po ukazaniu się komunikatu o błędzie operator może poza tym 
poinformować system, że owo "podejrzane” działanie programu 
jest prawidłowe, co powstrzyma wydawanie komunikatu o błę¬ 
dzie. 

Podobnie do programu ”Disk Watcher” pracuje *’Vaccine Uti- 
lity” autorstwa Paula Mace. Tak jak ”Disk Watcher” rezyduje 
on w pamięci i nadzoruje operacje na dyskietkach lub na dysku 
twardym. Strategia obronna *’Vaccine” polega na założeniu, że 
wirus daje o sobie znać zwykle poprzez manipulowanie w ob¬ 
szarach systemowych dyskietek i twardych dysków. ”Vacci- 
ne” nadzoruje je i nie dopuszcza do zapisu w tym obszarze. W 
razie takiej próby program zgłasza błąd i prosi operatora o pod¬ 
jęcie decyzji, czy kontynuować, czy zatrzymać pracę systemu. 
Alternatywnie do tego trybu program posiada drugi poziom 
ochrony, polegający na blokowaniu wszelkich prób zapisu na 
dyskietce lub twardym dysku. Słabością ”Vaccine” jest to, że 
opiera się jedynie na przerwaniach sprzętowych, odpowiedzia¬ 
lnych za operacje dyskowe. Stąd każdy twórca wirusów znający 
”Vaccine” nie ma specjalnych problemów z obejściem ochrony 
tego programu. 

”Virusafe” firmy Comnetco składa się z trzech programów, któ¬ 
re działają niezależnie od siebie. Pierwszy z nich sprawdza, czy 
w pamięci operacyjnej komputera znajdują się rezydentne pro¬ 
gramy zachowujące się nietypowo. Powinien on znajdować się 
na końcu pliku AUTOEXEC.BAT i być wykonywany, gdy kom¬ 
puter zachowuje się anormalnie. Właściwy program wyszukują¬ 
cy wirusy jest także i tu rezydentny. Charakteryzuje go mała za- 
jętość pamięci - tylko 6 KB. Przy sprawdzaniu operacji zapisu na 
plikach programowych ostrzega użytkownika, gdy tylko jakiś 
program próbuje załadować się rezydentnie do pamięci opera¬ 
cyjnej. Jeśli użytkownik zechce temu zapobiec, nie zostaje mu 
jednak nic innego jak na nowo wystartować komputer. Trzecia 
część ”Virusafe” "Program intergrity check” (PIC) jest najbar¬ 
dziej czasochłonna. PIC wylicza w wyspecyfikowanych wcześ¬ 
niej programach .EXE lub .COM sumy kontrolne i zapisuje datę 
utworzenia oraz dokładną długość pliku programowego. W mo¬ 
mencie uruchomienia programu sprawdzane są wszystkie pliki 
objęte listą. O wszelkich ewentualnych zmianach informuje na¬ 
stępnie użytkownika. Za największą wadę ”Virusafe” uważa się 
uciążliwą ochronę przed kopiowaniem. Poświęcono jej zbyt 
dużo miejsca w instrukcji obsługi, przez co tylko niewiele stron 
zostało na opis właściwych funkcji programu. Poza tym pro¬ 
gram ten daje się zainstalować tylko na twardych dyskach o 
symbolu ”C:”. 

Zupełnie inną strategię wykrywania wirusów stosuje ”VirusEx” 
napisany przez Josefa Seiferta. Jest on najbardziej zbliżony do 
koncepcji przeciwciał. ”VirusEx” jest programem, który doko- 
piowuje się bezpośrednio na początku programu i przez zaszyf¬ 
rowanie czyni go nienaruszalnym. Ponadto program jest dodat¬ 
kowo badany na ewentualne zmiany na podstawie sum kontrol¬ 
nych. Niestety ”VinisEx” zdolny jest chronić jedynie pliki typu 
.COM o wielkości do 64 KB. Ograniczenia te nie stoją na przesz¬ 
kodzie skutecznej ochronie. W większości przypadiców wystar¬ 
czy bowiem ochronić interpreter rozkazów i zewnętrzne (niere- 
zydentne) rozkazy MS DOS. To właśnie one atakowane są w 
pierwszej kolejności przez większość wirusów. Za wadę ”Viru- 
sEx” uważa się natomiast to, że wyświetla komunikat świadczą¬ 


cy o jego obecności tylko przy manipulacji. Nie jest wobec tego 
w stanie poradzić sobie z wirusami destrukcyjnymi, ponieważ 
piszą one na całym pliku programowym, a więc unicestwiają je¬ 
dnocześnie także program ochronny. 

"CHIP” 2/89 
Opracowanie Maciej Borkowski 


OD REDAKCJI: Szereg dodatkowych informacji o wirusach i sposobach ich zwalczania znajdzie 
Czytelnik w artykułach: "Wirusowa gorączka" i "Polski wirus" ("Komputer 11/88) oraz w wydanej 
przez spółkę ALEA broszurze "Uwaga wirus!". 
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Jakub Tatarkiewicz 


Hej ho, Hej ho! 
Do pracy... 


No właśnie, dlaczego niby miałoby się do pracy iść?! Alvin Tof- 
fler w swej słynnej książce "Trzecia fala" (polskie wydanie: PIW 
1986) przewidywał już w roku 1980, że niedługo świat zmieni się w 
jedną, wielką wioskę elektroniczną. Poglądy To filera dadzą się 
streścić następująco: rozwój techniki komputerowej i teletransmi¬ 
sji danych doprowadzi do tego, że większość ludzi będzie praco¬ 
wała w domu. Już i teraz w najbardziej rozwiniętych krajach tylko 
nieznaczny procent wszystkich zatrudnionych pracuje w produkcji 
przemysłowej lub w rolnictwie (w USA odpowiednio 9 i 13% 
wszystkich pracowników). Natomiast rosnąca liczba ludzi zajmuje 
się przetwarzaniem informacji. Dzięki rewolucji komputerowej 
wszyscy oni mogą pracować w domu. Pociągnie to za sobą oczywi¬ 
ste zmiany, zarówno w życiu społeczeństwa, jak i jednostek, m.in. 
cementując rodzinę jako podstawową jednostkę społeczną. Nie 
wspominam o efektach ekonomicznych, gdyż te są oczywiste: 
koszt teletransmisji danych jest znikomy w porównaniu z ceną tran¬ 
sportowania ludzi do i z pracy. Nb. nasuwa się myśl, że być może 
w ten sposób zostanie urzeczywistnione marzenie wielu pokoleń - 
zamiast przenosić się z miejsca na miejsce, będziemy mogli prze¬ 
nosić nasze myśli i najważniejsze zmysły (oczy i uszy). A więc bę¬ 
dziemy osiągali też nowe efekty psychologiczne, bowiem przyję¬ 
cie pewnika, że praca umysłowa jest podstawową czynnością czło¬ 
wieka, jest nam na razie obce. Proletariat inteligencki?... 

Powyższe rozważania nie są próbą fantastyki. Stali Czytelnicy 
"Komputera” wiedzą już, że propaguję od dawna całkowite skom¬ 
puteryzowanie prac biurowych (i nie tylko! Mam cichą nadzieję, że 
każdą pracę w dziedzinie przetwarzania informacji da się prędzej 
lub później skomputeryzować, ułatwiając pracę i zwiększając kre¬ 
atywność pracowników). Opisany przeze mnie jakiś czas temu 
program Jazz ("Komputer” 2/86) był jedną z pierwszych prób tota¬ 
lnego skomputeryzowania biura. Miał jedną wadę: był bardzo trud¬ 
ny w obsłudze, choć dynamiczne połączenie różnych elementów 
0’ak płachta, grafika, teksty i baza danych) pozwalało na dziecinnie 
proste poprawianie i zmienianie końcowego "wyrobu”, jakim było 
sprawozdanie, wysyłane drogą telefoniczną. Opisany rok później 
("Komputer” 3/87) program Excel był próbą oparcia integracji o 
płachtę, niemalże całkowicie ignorującą przetwarzanie tekstów i 
telekomunikację. 
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Dziś chciałem opisać (maję.c nadzieję, że pomogę w ten sposób 
Czytelnikom "Komputera” w planowaniu przyszłości zawodowej) 
kolejny i chyba najlepszy program zintegrowany: Microsoft 
Works (ang. works znaczy prace). Firma Microsoft jest konsek¬ 
wentna w dostarczaniu na rynek oprogramowania porządnych 
programów, dopracowanych i przemyślanych, choć nigdy rewolu¬ 
cyjnych. Tak jest i z omawianymi PRACAMI (rys. 1): znający już 


cyjnych. Tak jest i z omawiany¬ 
mi PRACAMI (rys. 1): znając już 
inne programy Microsofta nie 
będą mieli kłopotów z domyśle¬ 
niem się, do czego służy plik 
Resume Works. Podobnie 
kolejne okna, jakie widzi się 
po wystartowaniu programu 
(rys. 2) same się tłumaczą. 
Oczywiście znowu nie podano 
nazwisk programistów. Spotka¬ 
łem się ze zdaniem, że w ten 
sposób firma chroni swe naj¬ 
większe dobro, gdyż nikt nie 
może zaoferować tym ludziom 
wyższych apanaży... Natomiast 
zadbano o pełną zgodność 
(proszę bardzo korektę o nie 
poprawianie tego słowa "kom¬ 
patybilność”) programu nie tyl¬ 
ko z innymi własnymi wyroba¬ 
mi, lecz także wszystkimi pro¬ 
gramami Macintosha. Komenda 
"Import file” pozwala czytać 
teksty standardowego proceso¬ 
ra tekstów MacWrite, pliki typu SYLK (specjalny format używany 
przez płachty) oraz popularne bazy danych. 

Oczywiście w wiosce elektronicznej najważniejsza jest łączność 
telefoniczna. Moduł telekomunikacyjny Works jest bardzo obszer¬ 
ny - proszę zauważyć (rys. 3), że potrafi on nawet imitować telefon 
z obracaną tarczą (ang. rotary dial), nic więc nie stoi na przeszko¬ 
dzie, by Maca z Works używać i w Polsce. Tak, modemy są już do¬ 
puszczone do użytku, ale jak niedawno oświadczył minister łączno¬ 
ści mamy wprawdzie wiele nowych central telefonicznych, m.in. na 
warszawskim Ursynowie, ale nie oznacza to jeszcze pełnej telefoni¬ 
zacji kraju, bo brakuje kabli. Swoją drogą Toffler wykazał niezbyt 
wielką przenikliwość: łatwo bowiem prorokować rewolucję tele¬ 
komunikacyjną w kraju, w którym są miasta, gdzie jest więcej tele¬ 
fonów niż mieszkańców. W Polsce takie proroctwa mogą potknąć 
się o kabelek... 

Baza danych Works jest oczywiście oparta o płachtę, a raczej o 
format płachty (rys. 4), bo poszczególne recordy są przedstawiane 
jako odrębne karty. Niestety - zarówno baza danych, jak i płachta 
nie pozwalają na stosowanie wielu krojów czcionek - nie ma to zna¬ 
czenia w USA, gdyż końcowy produkt, czyli raport, będzie forma¬ 
towany w procesorze tekstów, ale w Polsce niemożność wyboru 
czcionki z naszymi znakami narodowymi jest poważnym utrudnie¬ 
niem. Zresztą baza danych Works ma być raczej tylko pomocni¬ 
czym narzędziem - przecież poprzez telefon można się połączyć z 
każdą inną bazą danych! 

Natomiast płachta oraz sprzężony z nią moduł graficzny (rys. 5) 
są przyzwoite, choć znowu niczym rewolucyjnym się nie wyróżnia¬ 
ją. Ot, wypełniamy kolejne wiersze liczbami, czasami pozwalając 
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sobie na wykorzystanie poprzednich wartości. PrawdziyYi maniacy 
mogą oczywiście pracować przy użyciu Excela, transportując po¬ 
tem swoje płachty do Works. Muszę się zresztą przyznać Czytelni¬ 
kom, że postęp w konstrukcji płacht jest tak duży, że to, co było do¬ 
bre rok temu, teraz wydaje się przestarzałe: gdy dla porównania 
włączyłem Jazz (którego nie używam na codzień, bo jest zbyt 
skomplikowany), okazało się, że możliwości płachty w Jazzie są 
porównywalne z Works. Rok temu wydawały mi się wspaniałe, 
dziś po Excelu są niczym specjalnym. Postęp... 

Podkreślam, że płachta.Works, grafika oraz procesor tekstu nie 
są połączone dynamicznie: wcięcie rysunku w tekst jest trwałe, tzn. 
dokonanie zmian liczbowych na płachcie nie zmienia rysunku. A 
więc klasyczna, choć dobrze zrealizowana idea integracji poprzez 
plik wycinków. 

Rzeczywiście rewolucyjny jest w Works procesor tekstów (rys. 
6), nieco podobny do Worda tej samej firmy, lecz zdecydowanie 
bardziej dostosowany do schematu Macintosha (wybór menu, 
okna). Jest to pierwszy tego typu program, który umożliwia umiesz¬ 
czanie rysunków obok tekstu (w dotychczasowych procesorach 
tekstu dla Macintosha, ze względu na inny format tekstu i grafiki, 
rysimki mogły być umieszczane poniżej lub powyżej tekstów; do¬ 
piero programy do komputerowego składu gazetek po raz pierw¬ 
szy zaprezentowały przenikanie tekstów i rysimków). W Works 
wybrana grafika (tu wykres przeniesiony z modułu płachty i poka¬ 
zany w "odwrotce” po wybraniu) może być suwana (kursorem-łap- 
ką!) po stronie, przenikając się z tekstem. A więc wszystkie drobne 
elementy graficzne, jak ozdobniki, wzory (coś dla matematyków!) 
oraz rysimeczki można umieścić gdzie się tylko zamarzy. Co wię¬ 
cej, procesor tekstu w Works jest pierwszym (ach, te "piersi na 
świecie”...), który ma dodatkowe narzędzie do kreślenia linii i ra¬ 
mek w wielu grubościach. Przydaje się ta możliwość, gdy chcemy 
przenieść tabelkę. Wszyscy, którzy żmudnie stukali klawiszem ze 
znakiem odejmowania lub podkreślenia, by oddzielić następny 
wiersz tabeli, wiedzą jaką olbrzymią pomocą może być gotowa li¬ 
nijka lub ramka. 

Wreszcie ostatnia i chyba najprzyjemniejsza cecha Works: pro¬ 
gram może otworzyć do 10 (tak, do dziesięciu!) okien na raz, choć 
ze względu na system operacyjny Macintosha tylko jedno okno 
może być aktywne (rys. 7). Ponieważ okna tekstowe mogą mieć 
grafikę, a baza danych nieco przypomina płachtę, więc w nazwie 
każdego okna program podaje skrótową nazwę rodzaju (WP ozna¬ 
cza procesor tekstu, CM - telekomunikację, SS - płachtę, a DB - 
bazę danych). 

Chcąc, mimo telefonicznej poczty, zrobić wydruk przygotowa¬ 
nego raportu (lub innych wyników pracy), napotykamy kolejny 
przykład dopracowania programu przez firmę Microsoft. Prócz 
standardowego okna drukarki (górna część rysunku 8) pojawia się 
także miejsce na nagłówki i odnośniki (ostatecznie warto numero¬ 
wać strony, bo co byłoby, gdyby się kartki rozleciały... Kody &C&P 
oznaczają pisanie centrowane numeru kolejnej strony). 

Uważni Czytelnicy zauważyli być może w prawych, górnych ro¬ 
gach kolejnych kopii ekranów liczby, podające aktualny czas. Nie 
mają one związku z Works, lecz są generowane przez zegar syste- 
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mowy. Chcę jednak zwrócić uwagę, że programiści Works nie na¬ 
dużywali możliwości w menu i dzięki temu w każdym z modułów 
czas nie przenika się z ostatnim menu: piszę o tym, ,l?o w większości 
programów zintegrowanych ma się do czynienia z istną orgią mo¬ 
żliwości. A to bardzo utrudnia pracę przeciętnemu użytkownikowi. 

Żałuję, że artykułu tego nie mogę przesłać bezpośrednio z mej 
wioski elektronicznej do wiosek elektronicznych Czytelników 
"Komputera”. Może kiedyś, gdy wszyscy będziemy mieli telefony... 


Od redak<^i: Program dostępny jest także w wersji dla PC. 
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Dzięki uprzejmości pana Mariana Reiskiego, dyrek¬ 
tora importowo-exportowej firmy Rema electronics Alt 
Moabit 74 1. OG, 1000 Berlin 21, tel.: 030/3912066, telex: 
186874 rema d, redakcja mogła testować i korzystać 
przez pewien czas z komputera Hyundai XT. 
Dziękujemy! 

W większości przypadków, gdy jest mowa o komputerach zgod¬ 
nych ze standardem IBM XT myślimy o wyrobach dalekowschod- 
I nich. Nieodparcie kojarzą się z tymi produktami Tajwan, Singapur 
lub Hongkong. Nie nieży jednak zapominać, że obok tych centrów 
elektroniki jest też na Dalekim Wschodzie kilka innych, o bardzo sil¬ 
nym potencjale produkcyjnym, koncernów elektronicznych. Jeden z 
nich to koreański koncern Hyundai. Nazwa koncern jest chyba naj¬ 
lepszym określeniem tej firmy. Zakłady Hyundai zajmują się produk¬ 
cją elementów elektronicznych, sprzętu audio-wizualnego, anten sa- 
telitamych, komputerów, środków łączności, tworzyw sztucznych, 
wyrobów metalowych, samochodów osobowych, a także ciągników 
rolniczych i maszyn roboczych. 

Dostarczony do redakcji komputer jest pierwszym elementem łań¬ 
cucha komputerów firmy, który zaczyna się modelem XT, kończy 
maszynami z 32-bitowym procesorem Intel 80386. 

Testowany Hyundai XT to typowy przedstawiciel komputerów 
zgodnych ze standardem IBM XT. Skonstruowano go tak, aby maksy- 
maMe obniżyć koszty produkcji z zapewnieniem pełnej funkcjonal¬ 
ności i zgodności ze wzorcem. 

Komputer wyposażony jest w płytę główną typu ”baby”. Na płycie, 
oprócz procesora 8088-1, pamięci RAM, ROM, układów wspomaga¬ 
jących, zarządzających pamięcią, kontrolujących przesyłanie da¬ 
nych, sterujących przerwaniami, zamontowano także sterownik na¬ 
pędów dyskowych, interfejs równoległy typu Centronics oraz inter¬ 
fejs szeregowy typu RS 232 C. Płyta nie zawiera sterownika obrazu. 
Do budowy pł^^y głównej użyto procesora produkowanego przez fir¬ 
mę Siemens. Tak jak w innych tego typu konstrukcjach procesor tak¬ 
towany jest przełączanym zegarem o częstotliwości 4,77 MHz lub 10 
MHz. Zegar można przełączyć zworką na płycie lub naciśnięciem se¬ 
kwencji klawiszy Alt Ctrl i Enter. Przełącznik na płycie uaktywnia ze¬ 
gar uruchamiany po włączeniu zasilania. Procesor komputera współ¬ 
pracuje z pamięcią RAM o pojemności 640 KB. Zastosowano układy 
pamięci DRAM Texas Instrument 4256 o czasie dostępu 120 ns. Pozo¬ 
stałe układy niezbędne do budowy komputera wyprodukowane są 
przez firmy NEC, Toschiba i Hitachi. Zainstalowany na płycie głównej 
sterownik dyskowy może obsługiwać dwa 40-ścieżkowe napędy dla 
dyskietek 5,25 cala. Dyskietki zapisywane są do pojemności 360 KB. 
W testowanym komputerze zastosowano dwa napędy dyskietek fir¬ 
my Panasonic. Płyta główna komputera ma pięć gniazd dla kart roz¬ 
szerzenia, z których jedno zajęte jest przez kartę sterownika monito¬ 
ra. Zastosowano przełączaną kartę sterownika ekranowego. Może 
ona tworzyć obraz tak, jak kolorowa karta graficzna (CGA), lub jak 
karta Hercules (grafika o wysokiej rozdzielczości). W trybie koloro¬ 
wej karty graficznej sterownik umożliwia podłączenie monitora kolo¬ 
rowego sterowanego sygnałem TTL lub całkowitym sygnałem wizji 
(coiuposite videó). Możliwa jest także współpraca z monitorem mo¬ 
nochromatycznym. W trybie karty Hercules sterownik współpracuje 
z monitorem monochromatycznym przez wyjście TTL. Przełączanie 
funkcji karty wizyjnej odbywa się przełącznikiem zamontowanym we 


I wsporniku rnocującym kartę w komputerze lub programowo progra¬ 
mem z załączonej do karty dyskietki. 

Do komunikacji z komputerem zastosowano klawiaturę typu RT o 
101 klawiszach. Obudowa klav7iatury wykonana jest z tworzywa sztu¬ 
cznego i ma znaczne wymiary. 

Wszystkie elementy elektroniczne wraz ze 120-watowym zasila¬ 
czem umieszczone są w małej obudowie metalowej. 

Komputer Hyundai XT wyposażony był w monitor monochromaty¬ 
czny o przekątnej ekranu 14 cali. Obraz tworzony na ekranie miał bia¬ 
łą barwę. Monitor mógł być sterowany sygnałem TTL wysyłanym 
przez kartę CGA lub kartę Hercules. 

W czasie użytkowania komputera nie swierdziłem żadnych wad, 
które zakłóciłyby jego normalną eksploatację. Wszystkie interfejsy 
pracowały poprawnie. Napędy dyskowe czytały dyskietki zapisywa¬ 
ne przez inne komputery i nie powodowały powstawania błędnych 
zapisów. Z uruchamianiem programów t^że nie było kłopotów. 
Wszystkie jakimi się na co dzień posługuję pracowały dobrze. Uru¬ 
chamiane programy testowe poprawnie wykrywały konfigurację 
maszyny i stwierdzały prawidłowe jej działanie. Program testujący 
szybkość pracy komputerów XT/AT SPEED.COM firmy Landmark 
Software wykazał, że z zegarem 4,77 MHz Hyundai XT pracuje dokła¬ 
dnie z szybkością wzorca IBM. Z zegarem 10 MHz zaś 2,1 raza szyb¬ 
ciej niż wzorzec IBM XT. 

Program MIPC.COM określający szybkość przetwarzania infor¬ 
macji wykazał, że testowana maszyna przetwarza średnio 0,21 mips 
(milionów operacji na sekundę), gdy użyty jest zegar 4,77 MHz oraz 
0,44 mips, gdy procesor taktov.'any jest zegarem 10 MHz. 

Na wysoką ocenę zasługuje monitor komputera. Obraz wyświetla¬ 
ny przez to urządzenie jest bardzo czytelny i wyraźny, bez deformacji 
lub zniekształceń. Przełączanie komputera i praca w trybie graficz¬ 
nym nie powodują żadnych nieprzyjemnych zjawisk. Obraz na ekra¬ 
nie jest bardzo stabilny i nie występuje męczące dla oczu migotanie. 
Monitor pracuje bezgłośnie, nie ma przykrego dla operatora sycze¬ 
nia układu wysokiego napięcia. Monitor komputera Hyundai w połą¬ 
czeniu z wielofunkcyjną kartą wizji daje bardzo duże możliwości w 
posługiwaniu się posiadanym opro^amowaniem. Nie ma kłopotów 
związanych z koniecznością emulacji programowej karty CGA przez 
kartę Hercules, gdy zachodzi potrzeba korzystania z graficznych 
programów przeznaczonych tylko dla karty CGA. Takie problemy 
niejednokrotnie występują przy uruchamianiu programów rozryw¬ 
kowych (gier) lub starszych wersji programów graficzno-rysunko- 
wych. 

Elementem najsurowiej ocenianym przy testowaniu każdego kom¬ 
putera jest klawiatura. Od jej działania zależy sprawność w posługi¬ 
waniu się komputerem. Klawiatura testowanego Hyundaia ma układ 
klawiszy zgodny ze standardem RT i wyposażona jest w dodatkowo 
powtórzone klawisze sterujące ruchem kursora, które znajdują się na 
klawiaturze numerycznej. lUawisze funkcyjne (FI -F12) umieszczone 
są nad klawiaturą liter i cyfr. Działanie klawiszy testowanej klawiatu¬ 
ry było poprawne, nie zacinały się i nie powodowały wprowadzania 
błędnych znaków. Klawiatura ma obudowę z tworzywa sztucznego, 
co powoduje, że jest stosunkowo lekka i zbyt łatwo można ją przesu¬ 
wać po laminowanym blacie biurka. Z komputerem połączona jest 
dość sztywnym przewodem zwiniętym w spiralę, co nie pomaga w 
swobodnym posługiwaniu się nią. Umieszczenie gniazda dla podłą¬ 
czenia klawiatury na bocznej lewej ściance obudowy komputera tak¬ 
że nie ułatwia posługiwania się nią. Wystająca wtyczka z przewodem 
z bocznej ścianki komputera uniemożliwia dosunięcie go do ściany 
lub wsunięcie w lukę między innymi elementami miejsca pracy. Sytu¬ 
ację poprawia fakt, że obudowa jest bardzo mała (niewiele większa 
od podstawy monitora) i zajmuje połowę miejsca typowej obudowy 
komputerów standardu IBM PC. 

Do komputera dołączony jest system operacyjny MS-DOS w wersji 
3.30, interpreter języka GW Basic w wersji 3.22 oraz dyskietka z opro¬ 
gramowaniem umożliwiającym wykorzystanie możliwości przełą¬ 
czanej karty graficznej. Oprogramowanie to pozwala między innymi 
na wyświetlanie w tekstowym trybie karty Hercules 132 kolumn tek¬ 
stu. Opcja ta jest bardzo przydatna, szczególnie przy posługiwaniu 
się skomplikowanymi bazami danych lub tworzeniu tekstów z wielo¬ 
kolumnowymi tabelami. Do dyskietek z programami dołączone są in¬ 
strukcje opisujące funkcje systemu operacyjnego, interpretera, spo¬ 
sób poshigiwania się, uruchamiania i testowania. 

Na uwagę w testowanym komputerze zasługuje bardzo staranny 
montaż wszystkich elementów, z jakich jest zbudowany. Wewnątrz 
obudowy nie ma zbędnych części, nadmiaru plączących się przewo¬ 
dów. Wszystkie wkręty mocujące wkręcone były poprawnie (co 
rzadko się zdarza, szczególnie w tanich produktach z Tajwanu), po¬ 
krywa obudowy pasowała do ściany frontowej (bez szpar) i pokryta 
była starannie wykonaną powłoką lakierniczą. Komputer w czasie 
pracy nie był hałaśliwy, mimo pracującego ciągle wentylatora umie¬ 
szczonego wewnątrz zasilacza sieciowego. Ogólnie Hyundai XT robi I 
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Na cenzurowanym 
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na użytkowniku bardzo pozytywne wrażenie. Gdybym miał dłużej 
pracować przy tym komputerze, to chyba postarałbym się o inną kla¬ 
wiaturę i to nie ze względu na jakość tej dostarczonej, lecz z powodu 
niewygodnego rozłożenia klawiszy standardu RT. (Jak do tej pory 
najlepszy rozkład mają klawiatury typu AT.) 

Podsumowując należy stwierdzić, że komputer Hyundai jest urzą¬ 
dzeniem bardzo starannie wykonanym, zapewniającym długie i po¬ 
prawne działanie. Wyposażony jest w bardzo dobry monitor i wygo¬ 
dną kartę graficzną. Biorąc pod uwagę jego cenę może być ofertą dla 
coraz liczniejszej rzeszy prywatnych użytkowników komputerów 
standardu PC. 


> 40 




<OmPUCE^ 39 












































Na cenzurowanym 
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Marek Car 


DTP 

do Amstrada 


• bardzo dobra zgodność ze wzorcem IBM PC; 

• staranne i dokładne wykonanie; 

• bardzo dobry monitor; 

• wygodna wielofunkcyjna karta graficzna. 


Wady komputera Hyundai XT: 


# gniazdo podłączenia klawiatury na bocznej ścianie obudowy; 

• zbyt lekka i duża klawiatura. 

m 


Zalety komputera Hyundai XT. 


" Program: TXT wer. 1.0 1 

Komputer; Amstrad CPC 6128 
Autorzy: Włodzimierz i Tadeusz Wypych 
Język: asembler 
System operacyjny: CP/M 
Cena: 50 tys. zł (bez edytora fontów) 

\ __ / 

Na taki program użytkownicy Amstrada CPC 6128 czekali zbyt 
długo. Sam komputer zdążył już zestarzeć się moralnie, gdy pod 
koniec 1988 r. na rynku pojawił się polski Desktop Publishing z pra¬ 
wdziwego zdarzenia: program TXT. Pod kilkoma względami prze¬ 
wyższa on nawet obliczone na klony IBM profesjonalne programy 
tego typu, jak Yentura Publisher czy Page Maker. 

Zachodni rynek oprogramowania DTP na ”malego” Amstrada 
jest ubożuchny. W zasadzie, poza programem STOP-PRESS (w 
pierwszej wersji znanym pod nazwą Page Maker), domy wydaw¬ 
nicze nie zaoferowały nic sensownego. Pewne elementy DTP (po¬ 
rządny edytor fontów) zawierał również pakiet graficzny ART STU¬ 
DIO, jednakże fatalny edytor tekstu uniemożliwiał praktycznie 
jego poligraficzne wykorzystanie na szerszą skalę. 

Pojawienie się na takim rynku programu autorstwa braci Wy¬ 
pych spowodować powinno (teoretycznie) olbrzymie zaintereso¬ 
wanie TXT. Niestety, chyba nie w naszym, przesiąkniętym do szpi¬ 
ku kości piractwem, kraju. Co innego na Zachodzie, np. w kolebce 
Amstrada - Wielkiej Brytanii. Tam rokuję autorom duży sukcśk 
Pod waiimkiem przygotowania wersji angielskojęzycznej i znale^ 
zienia wydawcy, który za solidne pieniądze (program jest ich wart) 
nabyłby prawa autorskie i rozpoczął dystrybucję. 

TXT - to pakiet programów do jedno- lub wieloszpaltowego 
składu tekstów i ich wydruku w trybie graficznym na drukarkach 
9-igłowych standardu Epsona. Wysoka jakość wydruku i precyzyj¬ 
ny skład sprawiają, że przygotowane za pomocą tego programu 
teksty, o praktycznie nieograniczonej objętości, mogą być następ¬ 
nie powielane techniką małej poligrafii (nawet z pominięciem eta¬ 
pu montażu). 

Wchodzący w skład pakietu EDYTOR pozwala tekst napisać. 
Pozwala także wczytać i zredagować tekst przygotowany wcześ¬ 
niej pod najpopularniejszymi edytorami na Amstrada 6128 - Prote- 
xtem, Taswordem i Wordstarem. Aby odczytać taki tekst wystar¬ 
czy zmienić jego nazwę (nadając jej rozszerzenie .TXT) - pakiet za¬ 
wiera również stosowny program narzędziowy do tego typu opera¬ 
cji dyskowych (DYSK). Dla wygody użytkownika program ten 
umożliwia ponadto formatowanie dysku, wyświetlanie jego katalo¬ 
gu, usuwanie zbiorów, przywracanie zbiorów omyłkowo skasowa¬ 
nych, kopiowanie wskazanych plików oraz podgląd treści pliku 
(bez edycji). Rutynowe operacje na plikach dostępne są również 
podczas edycji tekstów i ich druku. 

EDYTOR pakietu TXT oferuje praktycznie wszystkie możliwoś¬ 
ci najpopularniejszych edytorów tekstowych, włączając w to rów¬ 
nież operacje na blokach tekstu, dołączanie do edytowanego tek¬ 
stu pliku wskazanego w katalogu dysku, szukanie i zastępowanie, 
przypisywanie poszczególnym klawiszom fraz, które wpisywane 
są za naciśnięciem tego jednego klawisza, oraz dodatkowe możli¬ 
wości: wyróżnianie wskazanych słów pismem rozstrzelonym lub 
pochyłym (kursywą), okresowy, automatyczny zapis edytowanego 
tekstu. Jedynym ograniczeniem (w porównaniu np. z Taswordem) 
jest maksymalna długość edytowanego tekstu, wynosząca 31 tys. 
znaków. 

Program zawiera oczywiście polskie litery i umożliwia ich wyd- g 
ruk na drukarce. Co istotne - znakowa część klawiatury może być I 
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swobodnie konfigurowana przez użytkownika, zależnie od przyję¬ 
tego alfabetu. Istniejące wersje TXT zawierają (poza polskim) peł¬ 
ny alfabet rosyjski, oraz znaki narodowe alfabetu niemieckiego i 
francuskiego. Oczywiście żadne przeróbki sprzętowe nie są ko¬ 
nieczne. Takich możliwości nie daje żaden z istniejących edytorów 

tekstu ani DTP na ”małego” Amstrada. 

Napisany w EDYTORZE lub innym procesorze tekst wymaga 
przed wydrukiem złożenia, czyli nadania mu kształtu graficznego. 
Skład tekstu przebiega w pakiecie TXT dwuetapowo, co stanowi 
pewną niedogodność. Najpierw, jak na linotypie, składa się po¬ 
szczególne wiersze. Z gotowych wierszy, jak w zecemi, składa się 
kolumny tekstu. 

Wgląd w wykonywaną pracę umożliwia opcja wyświetlania pla¬ 
nu pojedynczej strony (znana np. z Yentury Publisher). TXT ofe¬ 
ruje jednak coś więcej — plan całego składanego tekstu, w którym 
poszczególne wiersze tekstu symulowane są na ekranie przez limę. 
Takiej opcji nie zawiera am Yentura, am skutecznie konkurujący z 
nią Page Maker, a więc programy obliczone na profesjonalny 
sprzęt klasy IBM, o meporównywame większych możliwościach 

technicznych! 

Menu składu zawiera tabelę parametrów składu, a więc szero¬ 
kość i długość szpalty, wysokość wiersza, szerokość spacji, głębo¬ 
kość wcięcia akapitowego, margines justowama, oraz format tek¬ 
stu, czyli numer gotowego zestawu powyższych parametrów zapi¬ 
sanych wcześniej na dysku. Takiego bogactwa możliwości nie daje 
żaden z istniejących programów na Amstrada CPC 6128. 

Jakby i tego było mało, autorzy przewidzieli również.możhwość 
płynnego metrampażu, czyli równoczesnej, proporcjonalnej zmia¬ 
ny szerokości kolumny składanego tekstu, przy zachowaniu pozo¬ 
stałych parametrów składu. Mając wgląd w plan całej publikacji, 
operując jedynie klawiszami i celem zwiększenia lub 
znmiejszenia szerokości składanego tekstu, można precyzyjnie za¬ 
mknąć tekst na zadanej wcześniej ilości stron, umknąć "bękartów”, 
czyli zaczynających się z akapitu pojedynczych wierszy na końcu 
strony lub ostatnich wierszy akapitu na nowej stronie, odpowiednio 
rozmieścić śródtytuły itp. Ani w programie Yentura, ani Page Ma¬ 
ker nie robi się tego tak prosto i szybko. 

Wróćmy jednak do naszego komputerowego linotypu, czyli 
składania wierszy. Procedura ta polega na formatowaniu po kolei 
każdego wiersza z takiej liczby znaków, by suma ich szerokości w 
druku jak najmniej różniła się od zadanej szerokości kolumny tek¬ 
stu. Pamiętać bowiem należy, że teksty składane pod TXT przezna¬ 
czone są do druku proporcjonalnego, w którym poszczególne zna¬ 
ki - inaczej niż w przypadku maszyny do pisama - mają niejedna¬ 
kową szerokość. Dlatego też długość wiersza mierzona jest w tym 
pakiecie nie liczbą znaków, a punktami drukarskimi. Podobnie, w 
punktach drukarskich, podawane są podstawowe parametry skła¬ 
du. 

Konieczność składu poszczególnych wierszy przed złożeniem 
całego tekstu wynika z konieczności podziału i przenoszenia słów. 
TXT dzieli i przenosi słowa na zasadach pełnej przypadkowości, 
wymagając jednak od użytkownika akceptacji sugerowanego po¬ 
działu lub jego banalnie prostego skorygowania. 

Program SKŁAD umożliwia również przygotowanie tekstu do 
druku dwuszpaltowego. Teksty złożone dwuszpaltowo zapisywane 
są na dysku z innym rozszerzeniem (TST), niż teksty jedynie przy¬ 
gotowane do druku pod EDYTOREM. Szkoda, że autorzy nie prze¬ 
widzieli również innego rozszerzenia nazwy (np. TZT) dla zapisy¬ 
wanych na dysku tekstów złożonych w układzie jednoszpaltowym. 
Dzięki temu łatwiej byłoby odróżnić na dysku roboczym teksty 
przygotowane do składu (.TXT) od tekstów już złożonych. 

Wspominałem już, że TXT przeznaczony jest w zasadzie do pro¬ 
porcjonalnie spacjowanego druku tekstów. Czasami zdarzają się 
jednak sytuacje, gdy optymalnym rozwiązaniem jest stały skok 
czcionki. Autorzy TXT przewidzieli możliwość składania tekstów 
czcionką o stałej szerokości (podobną do pisma maszynowego), 
która zapisana jest na dyskietce z programem. 

W ten sposób przeszliśmy do przedostatniego programu z pa¬ 
kietu TXT - DRUK. Jest to produkt w pełni profesjona^y. Dostęp¬ 
ne opcje - to wybór rodzaju druku (LO lub Draft), możliwość druku 
od konkretnej strony, przełącznik: papier ciągły/w arkuszach, pa¬ 
ginacja ze wskazaniem miejsca, gdzie umieszczony ma być numer 
strony, marginesy oraz długość arkusza papieru (w punktach). Do¬ 
datkowo program umożliwia sterowame drukarką, czyli wysuwa¬ 
nie papieru o jeden punkt drukarski, o jeden wiersz lub o stronę. 

Lepiej, niż w innych DTP, rozwiązany jest problem wizualizacji pra¬ 
cy. Podczas druku na ekranie p^ojawia się tekst drukowanej linii. 
Pewnym niedociągnięciem jest brak możliwości pomimęcia nu- 
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meracji określonych stron drukowanego tekstu (np. pierwszej i 
ostatniej). 

Wreszcie ostatni program pakietu, o nieco nieszczęśliwie dobra¬ 
nej nazwie, TYPO. Jest to edytor fontów, czyli krojów czcionki, 
umożliwiający jednoczesne definiowanie postaci graficznej zna¬ 
ków ekranowych i drukarkowych. Od wyboru użytkowmka zależy, 
czy edytować będzie się znak drukarkowy (matryca 21 x 25 pkt.), 
czy ekranowy (8x8 pkt.). Prostota obsługi programu jest w pęto 
skorelowana z szerokimi możliwościarcu edycyjnymi poszczegól¬ 
nych fontów. 

Dodatkowe zalety pakietu - to możliwość dowolnego konfiguro¬ 
wania klawiatury (niezbędna przy znanej różnorodności upodobań 
pań maszynistek) oraz parametrów uruchamianego programu: 
drukarki (7-czy 8-bitowa), fontu, w jakim edytowane mają być tek¬ 
sty, szerokości lewego marginesu wydruku i długości arkusza pa¬ 
pieru, częstości automatycznego zapisu tekstu. Niestety, z dołączo¬ 
nej do programu instrukcji nie wynika jednoznacznie, jakie w tym 
ostatnim przypadku wartości wchodzą w rachubę. * 

Pakiet sprzedawany jest w następującej konfiguracji: dwa pod¬ 
stawowe zbiory fontów ekranowych (polskie i obcojęzyczne, w 
tym cyrylica), dwa podstawowe zbiory konfiguracyjne klawiatury 
(w przypadku cyrylicy przyjęto fonetyczny wariant transkrypcji 
znaków polskich), cztery fonty, w tym trzy zawierające litery pols¬ 
kiego alfabetu: draft, LO, czcionka o stałej szerokości (z których 
każdy obejmuje pismo proste i kursywę), oraz jeden do dn^owa- 
nia tekstów obcojęzycznych. Na dyskietce zapisany jest też pełny 
tekst 12-stronicowej instiukcji obsługi programu. Jej autorzy zakła¬ 
dali, iż potencjalny czytelnik posiada już pewien zasób wiedzy o 
obsłudze komputera, co nie zawsze jest założeniem słusznym. 
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Miary 

Wynalazek Gutenberga był przełomowym wydarzeniem dla ro¬ 
zwoju drukarstwa. Jego czcionki odlewane z metalu stwarzały mo¬ 
żliwość wielokrotnego wykorzystania w procesie druku. Ponieważ 
ówczesne pisma drukarskie wzorowane były na piśmie odręcz¬ 
nym, wysokość pojedynczej litery dostosowana była do wielkości 
pisma odręcznego. Z czasem zaczęły powstawać wyspecjalizowa¬ 
ne warsztaty, odlewające czcionki dla oficyn wydawniczych. Oka¬ 
zało się, że każda z nich stosowała inne wielkości czcionek i unie¬ 
możliwiało to wykorzystanie i łączenie nowo zakupionych wzorów 
z już posiadanymi. 

Należało więc uporządkować panujący chaos. Jako pierwszy w 
XVII wieku próbował ujednolicić wymiary czcionek Anglik Joseph 
Moxon. Jego system oparty był oczywiście na ówczesnej stopie an¬ 
gielskiej. Został udoskonalony również przez Anglika - Williama 
Calsona, który w latach trzydziestych XVIIIw. wydał obszerny 
wzornik pism swojej odlewni. Ich wielkości mieściły się bez reszty 
w stopie angielskiej. Wielkości miar Calsona przyjęły się w Anglii 
i krajach zależnych oraz w Stanach Zjednoczonych i nazwane zosta- 
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ły systemem Pica. W Europie zadania podporządkowania rynku 
podjął się Pierre Fourier, francuski drukarz i odlewnik czcionek. 
Swój system oparł o wymiary stopy francuskiej (równej 300 mm), 
którą podzielił na 12 cali, cal na 12 linii, linię na 12 punktów. Niedo¬ 
skonałość tego podziału związana była z różną wielkością stopy 
stosowanej w każdym mieście Francji. Dopiero wprowadzenie jed¬ 
nolitej ”stopy paryskiej” pozwoliło Francois Didotowi na ujednoli¬ 
cenie miar typograficznych: stopa dzieliła się na 12 cali, cal na 12 li¬ 
nii, punkt miał wielkość 1/6 linii. Potomek Francois Didota - Firmin 
- jako pierwszy w świecie zaadaptował miary typograficzne do 
obowiązującego od 1790 roku we Francji układu metrycznego. 
Spowodowało to jednak zamieszanie wśród drukarzy, gdyż w róż¬ 
nych częściach Europy stosowano niejednakowe systemy. W 1879 
roku niemiecki odlewnik Herman Berthold dostosował wielkości 
typograficzne do systemu metrycznego. I tak okazało się, że 1 
punkt typograficzny równał się 1/2660 części metra, czyli 0,375940 
mm. Układ ten został zalegalizowany w większości krajów eiuo- 
pejskich i od roku 1970 obowiązuje także w Polsce. Ustalono, że 
podstawową jednostką typograficzną systemu Didota (Bertholda) 
jest punkt typograficzny równy 0,376065 mm (~0,376 mm). Jednos¬ 
tką jest punkt a praktyczne znaczenie mają także inne jednostki: 
cycero =12 punktom i kwadrat = 4 cycerom = 48 punktom. 

Kraje anglojęzyczne stosują jednostki oparte na systemie calo¬ 
wym. I tak: cal angielski (25,4 mm) dzieli się na 6 pica (skrót od 
American Point), 1 pica = 12 point, point = 0,1667 cala, czyli 12 po¬ 
int = 0,351 mm, co stanowi 1/72 części cala. Podstawową jednostką 
jest tu także punkt typograficzny zwany pica (czyt. pajka) równy 
1/12 części cala. W Polsce podział ten nazwano systemem Pica. 



Wszystkie te "zabiegi” miały swój cel - piękno i estetykę powsta¬ 
jącego druku. W uporządkowanym systemie jest to o wiele łatwiej¬ 
sze, niż w chaosie wynikającym z braku jednostek i zasad. 

Obecnie, gdy do poligrafii wkroczyły komputery, znajomość po¬ 
szczególnych systemów miar typograficznych nie jest już tak nieo¬ 
dzowna. Profesjonalne stanowiska składu pracują w dowolnym sy¬ 
stemie. Nadal jednak obowiązuje estetyka i piękno druku jako cele 



oczko czcionki 


główka czcionki 


słupek 



sygnatura główna 


J —V 


Budowa typowej czcionki odlewanej 


nadrzędne. Nie jest ważne kto posługuje się jakim systemem, ale 
jak kształtuje swoje "dzieło”, którym w tym przypadku jest np. wi¬ 
zerunek strony, tabeli czy sprawozdania. Obecnie każdy, kto jest 
szczęśliwym właścicielem komputera lub ma do niego dostęp, 
może i powinien zwrócić na to uwagę. Rozpowszechnienie progra¬ 
mów DTP przybliża Czytelnika do zagadnień związanych z syste¬ 
mami typograficznymi. Prawie każdy z tych progrćimów może pra¬ 
cować w jednym z zadanych układów miar typograficznych. 

W każdym programie DTP mamy do czynienia z literami, ale czy 
wiemy jaka jest ich rzeczywista wysokość czy szerokość? W poli¬ 
grafii tradycyjnej, każda litera - jest to prostopadłościan metalowy, 
na którego górnej części znajduje się wypukły, odwrócony (lewo- 
czytelny) obraz litery, cyfry, znaku czy linii. Górna część czcionki 
nazywa się główką, na jej powierzchni znajduje się oczko czcionki, 
czyli górna płaszczyzna główki, dająca w druku obraz litery, cyfry, 
znaku czy linii. Pozostała część prostopadłościanu tworzącego 
czcionkę nazywana jest słupkiem. 

Jak widać na rysunku oczko litery nie zajmuje całej powierzchni 
główki w czcionce. Odstęp między krawędzią oczka litery i ścianą 
słupka nazywany jest odsadką. Dla każdego, kto zajmuje się skła¬ 
daniem tekstów jest to wielkość bardzo ważna, ponieważ wyzna¬ 
cza ona linię pisma. A zatem linią pisma jest prosta styczna do dol¬ 
nej krawędzi rysunku liter małych i wielkich bez wydłużeń dol¬ 
nych, np. H, h, B, b. A, a. Linią górną jest prosta równoległa do linii 
pisma, pokrywająca się z krawędzią wydłużeń górnych liter bez 
akcentów, np. liter A, B, b, H, h. 

Poszczególne wiersze w składzie muszą mieć równą linię pisma, 
niezależnie od wielkości użytych czcionek (muszą byc "postawio¬ 
ne” swą dolną krawędzią na tej samej linii). 

W programach DTP mamy do czynienia z obrazem liter kształto- 
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Dziedzictwo Gutenberga 






linia akcentów 



linia górna 


linia średnia 


linia pisma 


linia dolna 


Linie pisma. Odległość między linią akcentów a linią dolną nazywana jest stopniem pisma. 


wanych w sposób ”nie materialny”. Nadal jednak obowiązują tu ta¬ 
kie same zasady jak przy składzie tradycyjnym. Komputeryzacja 
pozwala na tworzenie przez użytkownika poszczególnych liter lub 
całych krojów we własnym zakresie. W zależności od wielkości 
tworzonego znaku musi on być opisany na odpowiednio dobranej 
matrycy. Trzeba natomiast zachować dla wszystkich znaków jed¬ 
nakową linię pisma, linię górną a także odsadkę. 

Należy tu również wsponmieć o szerokościach poszczególnych 
znaków. Przy pracy z komputerami i ich otoczeniem najczęstsza 
wymiana informacji polega na czytaniu komunikatów wypisywa¬ 
nych na ekranie monitora lub drukowanych na drukarkach. W 
przypadku pojawienia się komunikatów ekranowych najczęściej 
mamy do czynienia z pismem proporcjonalnym, to jest takim, w 
którym wszystkie znaki opisane są na matrycy o tej samej wielkoś¬ 
ci - jednakowa szerokość każdego znaku. Przy druku informacji 
dostarczanych z komputera na popularnych drukarkach również 
czytamy pismo proporcjonalne. Pismo takie wykorzystywane jest 
także w maszynach do pisania. Używanie pisma proporcjonalnego 
jest rozwiązaniem bardzo ułatwiającym posługiwanie się tabelami 
lub zestawieniami, nie należy jednak do kanonów sztuki drukars¬ 
kiej. Używanie pisma proporcjonalnego na ekranach monitorów 
jest wynikiem małej ich rozdzielczości oraz przyjętymi ułatwienia¬ 
mi w programowaniu sterowników obrazu. 

Drukarki wyższej klasy umożliwiają druk znaków o różnej szero¬ 
kości - pismo nieproporcjonalne. W piśmie nieproporcjonahiym 
każda litera ma swoją określoną szerokość, która jest minimalnie 
większa od rysunku litery. Tak więc widząc literę ”odbitą” na pa¬ 
pierze, widzimy tylko obraz jej oczka. Litera o wielkości 10 pun¬ 
któw typograficznych jednego kroju może mieć inną wielkość ocz¬ 
ka niż w innym kroju. Przy tworzeniu liter należy uważać na odpo¬ 
wiedni dobór szerokości poszczególnych znaków, szczególnie 
przy znakach wąskich np. 1, i, j, gdyż zbyt szeroka matryca może 
powodować złą czytelność i wygląd tych znaków w całym tekście. 

W chwili obecnej, gdy coraz częściej używane są drukarki lase¬ 
rowe ma to szczególnie ważne znaczenie. Zbyt szerokie znaki, nie¬ 
zgodne z matrycą danego kroju pisma, nieodpowiednie ustawienie 
ich w matrycy będzie powodować zlewanie się liter ze sobą w tek¬ 
ście i utrudniać jego czytelność. Należy o tym pamiętać, szczegól¬ 
nie przy uzupełnianiu zestawu liter danego urządzenia drukujące¬ 
go o znaki dodatkowe (przeważnie brakujące polskie znaki dia¬ 
krytyczne). Muszą one odpowiadać wszystkim zasadom budowy i 
wymiarów zestawu do jakiego mają być dołączone. Wymagają 
tego kształtowane od wieków kanony sztuki drukarskiej, a także 
podstawowe zasady estetyki. 

Rozwijająca się elektronika i idące za tym możliwości kompute¬ 
rów powodują, że w najnowszych konstrukcjach, oprócz poprawiania 
parametrów ich pracy, zwraca się także uwagę na zasady rządzące 


komunikacją komputer - człowiek. I tak w komputerze NeXT do 
wyświetlania liter na ekranie użyto mechizmów opisanych języ¬ 
kiem PostScript. Litery i znaki opisane są wektorowe (każdy znak 
zapisany jest w formie graficznych równań matematycznych), co 
pozwala na bezstopniowe ich powiększanie, zmniejszanie, pochy¬ 
lanie, a co najważniejsze powoduje v^świetlanie znaków niepro¬ 
porcjonalnych, zbudowanych według wzorców używanych po¬ 
wszechnie w druku. Ekran komputera NeXT jest jakby wydruko¬ 
waną, z bardzo wysoką jakością, planszą informacyjną. Sy¬ 



stem przyjęty przez konstruktorów NeXT-a wyznacza kierunek ro¬ 
zwoju nowej generacji komputerów i jest początkiem prawdziwej, 
profesjonalnej "drukami na biurku”, jak mówi się często o progra¬ 
mach typu DTP. 


m 
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Prawo autorskie 



POLSKIE 

TOWARZYSTWO 

INFORMATYCZNE 


STANOWISKO POLSKIEGO TOWARZYSTWA 
INFORMATYCZNEGO W SPRAWIE OCHRONY PRAWNEJ 
PROGMMÓW KOMPUTEROWYCH 15 grudnia 1988 r. 

1. W środowisku Polskiego Towarzystwa Informatycznego 
podnoszona jest od dłuższego czasu teza o konieczności ustano¬ 
wienia jednoznacznej ochrony prawnej programów komputero¬ 
wych. Przemawiają za tym - zgodnie z opinią środowiska - nastę¬ 
pujące argumenty: 

- ustanowienie takiej ochrony jest jednym z koniecznych warun¬ 
ków dla rozwoju krajowego przemysłu oprogramowania, bez ist¬ 
nienia którego nie może być mowy o postępie zastosowań informa¬ 
tyki w Polsce; 

- obserwowane w skali masowej zjawisko piractwa w dziedzinie 
oprogramowania powoduje wiele szkód w gospodarce narodowej 
poprzez fakt częstego używania oprogramowania niekompletnego 
i niewłaściwie udokumentowanego lub uszkodzonego w wyniku 
łamania zabezpieczeń; 

- kopiowanie na szeroką skalę oprogramowania zagranicznego 
bez zgody i woli producentów stanowi łamanie zasad przyjętych w 
obrocie w ich krajach i jest poważną barierą dla rozwoju prawidło¬ 
wych stosunków handlowych z tymi producentami; 

- sytuacja, w której można za darmo otrzymać kopie programów, 
stwarza społeczne przekonanie, że oprogramowanie nic nie kosz¬ 
tuje lub kosztuje niewiele. To przekonanie jest błędne i może mieć 
poważne skutki dla podejmowanych decyzji gospodarczych. 

2. Konieczność ustanowienia ochrony prawnej oprogramowa¬ 
nia jest ściśle zwijana z prowadzonymi analizami oraz wypowie¬ 
dziami przedstawicieli nauki prawa, z których wynika, że obowią¬ 
zujący w Polsce prawny system ochrony własności intelektualnej 
(prawo autorskie, prawo wynalazcze) jest w niedostatecznym stop¬ 
niu przystosowany do tego, aby mógł być podstawą jednoznacznej 
kwalifikacji programów komputerowych, jako przedmiotu ochro¬ 
ny. Fakt ten dostrzeżono w krajach wytwarzających oprogramowa¬ 
nie konriputerowe na skalę przemysłową, dokonując stosownej no¬ 
welizacji obowiązującego prawa autorskiego. Sugestie w tym za¬ 
kresie wynikają ponadto z prac Światowej Organizacji Własności 
Intelektualnej, Idórej członkiem jest Polska. 

3. Nie przesądzając ostatecznych rozwiązań legislacyjnych Pol¬ 
skie Towarzystwo Informatyczne podjęło prace nad zdefiniowaniem 
podstawowych elementów podmiotowego prawa bezwzględnego 
(prawo własności programu), mającego za przedmiot programy 
komputerowe. Podstawowe elementy definicji proponowanej przez 
Towarzystwo są załączone do tekstu niniejszego stanowiska. 

4. Polskie Towarzystwo Informatyczne prezentuje pogląd, że 
ochrona prawna programów komputerowych, będąc warunkiem 
koniecznym, nie jest jedynym wystarczającym warunkiem rozwoju 
przemysłu oprogramowania. Warunkami tego rozwoju są ponadto: 
właściwa polityka kredytowa i podatkowa, umożliwiająca odpo¬ 
wiednie inwestycje oraz właściwe dla przedmiotu produkcji zasa¬ 
dy rozliczania jej kosztów. 

Wprowadzane w kraju nowe zasady prowadzenia działalności 
gospodarczej oraz nowe zasady polityki finansowej powinny uwz¬ 
ględniać specyfikę produkcji oprogramowania, jej technologię 


oraz charakter powstających produktów. Możliwość uwzględnie¬ 
nia tej specyfiki jest ściśle związana z uregulowaniami dotyczącymi 
stosunków właściwych, tj. prawa własności programów. 

Wysokość opłat licencyjnych na rzecz producentów z II obszaru 
płatniczego, wymaganych od chwili wprowadzenia ochrony praw¬ 
nej oprogramowania, przytaczana jako argument przeciwko jej 
ustanowieniu, jest - zdaniem Towarzystwa - w znacznym stopniu 
wyolbrzymiona. Jest ona oceniana przy założeniu konieczności wy¬ 
korzystania wszystkich produktów programowych (oraz rozmai¬ 
tych ich wersji), które pojawiły się na rynku krajowym w wyniku pi¬ 
rackiego kopiowama. Potrzeby zastosowań informatyki wymagają 
znacznie mniejszej liczby tych produktów, sprowadzanych jedynie 
w określonych wersjach. Przy takim założeniu wysokość tych opłat 
należy szacować na znacznie niższym poziomie. Konieczność wno¬ 
szenia opłat stanowić może natomiast istotny czynnik dla prowa¬ 
dzenia ekonomicznie uzasadnionej selekcji oprogramowania im¬ 
portowanego i doprowadzić do praktyki dokonywania transakcji z 
nmiejszą liczbą producentów, co może mieć korzystny wpływ w za¬ 
kresie typizacji oprogramowania produkowanego w kraju. 

PROPOZYCJA DEFINICJI PODSTAWOWYCH 
ELEMENTÓW PRAWA WŁASNOŚCI PROGRAMU 

1. Przedmiotem prawa własności programu jest każdy program 
komputerowy ustalony w postaci: 

a) kodu programu w wersji do bezpośredniego wykonania przez 
komputer, 

b) tekstu programu w języku symbolicznym lub innej postaci umo¬ 
żliwiającej automatyczne wygenerowanie kodu programu w wersji 
do bezpośredniego wykonania przez komputer. 

1.1. Przedmiotem prawa własności programu jest również każdy 
szczegółowy opis programu, tj. taki opis, który umożliwia proste 
odtworzenie którejkolwiek z postaci, wymienionych w p. 1. 

2. Podmiotem prawa własności programu jest osoba, która poniosła 
nakłady na opracowanie programu. W szczególności, jeżeli program 
opracowany został w wykonaniu umowy o pracę lub umowy o dzieło, 
prawo własności programu służy pracodawcy lub zamawiającemu. ' 

2.1. Jeżeli kilka osób poniosło nakłady związane z opracowaniem 
programu, dla określenia prawa każdej z osób stosuje się odpo¬ 
wiednio przepisy prawa cywilnego dotyczące współwłasności. 

2.2. Domniemywa się, że prawo własności programu służy osobie, 
której nazwa uwidoczniona jest w szczegółowym opisie programu, 
lub która uwidoczniona zostaje w zewnętrznych przejawach działa¬ 
nia programu (np. na ekranie, wydruku lub rysunku). 

2.3. Bezpośrednim twórcom programu służy prawo ochrony dóbr 
osobistych, zgodnie z zasadami prawa cywilnego. Nie obejmuje 
ono jednak prawa do decydowania o sposobie wykorzystania pro¬ 
gramu przez właściciela prawa do tego programu. 

3. Prawo własności programu obejmuje prawo do: 

a) wyłącznego rozporządzania programem, 

b) pobierania przychodów z tytułu eksploatacji programu. 

3.1. Prawo własności programu może być w całości lub części 
zbyte innej osobie. 

4. Poszczególne uprawnienia w zakresie prawa własności progra¬ 
mu mogą być udzielone przez właściciela prawa do programu in¬ 
nej osobie w drodze umowy licencyjnej. 

5. Korzystanie z cudzego programu może odbywać się wyłącznie 
na podstawie umowy zawartej z właścicielem prawa do tego pro¬ 
gramu lub osobą uprawnioną wg zasad określonych w p. 4. 

6. Naruszeniami prawa własności programu są ponadto: 

a) kopiowanie programu, 

b) odtwarzanie tekstu programu w języku symbolicznym lub opisu 
programu na podstawie kodu programu w wersji do bezpośred¬ 
niego wykonania, 

c) wykorzystywanie istotnych rozwiązań zawartych w programie 
w opracowaniu innego programu, bez pisemnej zgody właściciela 
prawa do tego programu lub osoby uprawnionej wg zasad określo¬ 
nych w p. 4. 

7. Opublikowanie przez właściciela prawa do programu szczegó¬ 
łowego opisu tego programu w książce lub czasopiśmie uważane 
jest za wyrażenie zgody na swobodne wykorzystywanie programu 
oraź zawartych w nim rozwiązań. 

8. Usuwanie nazw osoby lub osób, którym przysługuje prawo wła¬ 
sności programu oraz stwarzanie w jakikolwiek sposób przekona¬ 
nia, że prawo to przysługuje innej osobie lub osobom są ścigane 
kamie. 

9. Właściciel prawa do programu lub osoba upoważniona wg za¬ 
sad określonych w p. 4 może żądać od każdego, kto narusza zasady 
określone w p. 5 i 6, zaniechania tych naruszeń oraz wydania korzy¬ 
ści materialnych. 

opr. Jacek Irlik 
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QR - TEKST 


QR - MULTI DRUK 
DATA SWITCH 


•$ 


- najefektywniejszy polski procesor tekstów 
z najszybszym 


słownikiem ortograHcznym 

Koniec z błędami w publikacjach 
i korespondencji! 

- wsp^racuje z bazami danych oraz programami 
graficznymi w systemach DOS i IPK XENDC 
szpaltuje teksty, drukuje w trybie znakowym 

Cena: 215.000 zł 

- szpaltuje teksty, drukuje w trybie znakowym 


DRUKARKA 


- automatycznie przełącza wyjścia komputerów przy 
współpracy z jedną wspólną drukarką 

- oszczędza czas i pieniądze 

- 2 lata gwarancji + serwis. 

Cena: 395.000 zł 


INFORMACJE + PRZYJMOWANIE ZAMÓWIEŃ: 

PHP OUATRONIC 02-495 WARSZAWA UL. BODYCHA 18, TEL. 662-64-13 


Ko-19L^99^05 






semi heavy duty, wielogłowicowe, produkcji japońskiej 

CPX'*80 - 10”, 4 głowice, 480 zn/sek, 250 linii^min -“^S.GOO.OOO zł 
CPX-136 - 15”, 6 głowic, 480 zn/sek, 214 linii/min - 5.400.000 zł 


Z 0.0. 

31-144 Kraków, ul. Biskupia 

(012) 33-19-08 


PRZEDSIĘBIORSTWO USŁUGOWO-HANDLOWE 

OSKAR” Sp. z 0 . 0 . 04-111 W-wa ul. Grochowska 207 
tel. 10-00-61 w. 203 DH "Uniwersam-Grochów” 


55 . 


OFERUJEMY: 


• gry - nowości, gotowe zestawy 

• literatura: Turbo Basic, LOGO cz. 1-3, Nauka programowania w Atan Basic, Gradika dla początkujących 
lub zaawansowanych. Instrukcja obsługi ST, Basic ST, Logo ST, Gem ST, Intern ST 

• programy edukacyjne dla szkół podstawowych i średnich na Atari XE 

POLECAMY: 

• interfejsy do magnetofonów ^ interfejsy TURBO ^^cjoystiki ^ dyskietki 

^ CENTRONIKS do drukarek ^ pudełka na dyskietki ^ Cartridge: Basic XE, Basic XL, Action, Logo, As- 
sembler Edytor, Pióro Świetlne. 

INSTALUJEMY: niezawodny system Turbo w magnetofonach firmowych 

PROWADZIMY SKUP I SPRZEDAŻ SPRZĘTU ATARI. Wysyłka pocztą. 

ZAPRASZAMY DO WSPÓŁPRACY SKLEPY ELEKTRONICZNE 


Ko-237'343t)5 


”OSKAR” Sp. z 0 . 0 . 

czynne w godz. 9.00 - 17.30 
tel. 10-00-61 w. 203 


Proszę o przysłanie katalogu; 
O ATARI XL/XE 
O ATARI ST 

MOJE DANE; 

Imię . 

Nazwisko. 

Adres . 


Załaczam znaczek z kopertą zwrotną 

Ko-246/341/05 
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Mikromarket 





uI.Leśna 7 

05-806 Komorów k. W 
tel.580679 


dostawy kompletnych komputerowych 
uk^fedow automatyzacji eksperymentów i 
procesów technologicznych w oparciu 
o renomowany sprzęt światowy : 

- moduły wejść/wyjść OPTO-22 

- szeregowy interfejs OPTOMUX 

- sterowniki BABY BLUE 2 PC 

- komputery przemysłowe AT 10 MHz oraz 

- system ekspertowy czasu rzeczywistego 
RTES a także 

- karty wejść/wyjść PC LabCards do kom¬ 
puterów IBM PC 


> 1 - 


Zadbaj o przyszłość swojej firmy. 

Zautomatyzowany System Zarządzania 

- sieciowe i wielodostępne środowisko (dostęp do danych na poziomie rekordu), 

- równoczesna i równorzędna praca wszystkich stanowisk, 

- wspólna baza danych, 

- modularne podsystemy: 

Księga Główna, 

Gospodarka Materiałowa, 

Gospodarka Finansowa, 

Kadry, 

Informowanie Kierownictwa, 

Płace, 

Środki Trwałe, 

- 2 nagrody na Targach Softarg ’88. 


ICRO 


YSTEM BIURO PROJEKTÓW I ZASTOSOWAŃ SYSTEMÓW INFO 

MicroSystem Sp. z o.o. od 1985 i.g.u. 

80-557 Gdańsk 
ul. Marynarki Polskiej 59 
tel. 43-05-24, 43-12-71 do 81 wew. 450 
tlx. 0512749 hwspl 


Ko-208'327.0 
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Mikromarket 








Drukarki 9-igłowe 


Typ 

CI-4000-10 

CI-4000-20P 

CI-4000-20S 


Prędkość druku 

(norm./NLQ) 
400/87 zn/sek 
400/87 zn/sek 
400/87 zn/sek 


DM 

4.430 

4.270 

4.270 


Moduły znakowe 
Model 10 
Model 20P 
Model 20S 

Instrukcje obsługi 
w jęz. angielskim 
w jęz. niemieckim 

Drukarki 24-igłowe 

Typ Prędkość druku 

(norm./NLQ) 

Tl 61 300/100 zn/sek 


DM 

518 

448 

448 

DM 

140 

40 


DM 


3.758 


W cenę drukarki wliczony jest interfejs oraz 
moduł znakowy. 


Kasety barwiące 
Opakowanie 6 sztuk 


DM 

80 





Urządzenia dodatkowe. 

i. 

Automatyczny podajnik kart 
pierwsza komora 
druga komora 
traktor 


DM 

581 

385 

371 


Powyższe modele drukują na papierze o 
szerokości do 406 mm. Przedstawiamy 
Państwu nowy produkt, bestseller w zasto¬ 
sowaniach przemysłowych i wszędzie tam, 
gdzie liczy się szybkość, jakość, wytrzyma¬ 
łość. Dzięki zastosowanym rozwiązaniom 
(różne rodzaje druku i różne emulacje zapi¬ 
sane na wymiennych kartach) drukarki firmy 
C.ITOH spełniają wymagania wielu różnych 
klientów. 

Na uwagę zasługuje bardzo wysoka pręd¬ 
kość (do 570 zn/sek w modelu C 815). God¬ 
na podkreślenia jest wysoka żywotność gło¬ 
wicy (do 100 min znaków w C 715,1 miliard 
znaków w C-4000). Zastosowana konstruk¬ 
cja prowadżenia papieru" umożliwia także 
drukowanie etykiet samoprzylepnych. 
Nowością na rynku drukarek jest 24-igłowa, 
bardzo szybka 7-kolorowa drukarka z sze¬ 
rokim 15” wałkiem C.ITOH 715 C. 


Zainteresowanych produktami innych 


prosimy o bezpośredni kontakt. 



ciiati 



instrument 


Roland 

DIGITAL GROUP 


AMPEX 
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TO NIE TYLKO KOMPUTERY... 

Bog'ata ofsrta sprzętu komput©row©go i ©l©ktroiiiczn©go powsz©chn©go 
i prof©sjonaln©go użytku zawsz© do ob©jrz©nia w Studiu Usług Komput©rowych 
SAMBA i zaprzyjaźnionych z nim firmach, a do zakupu w firmi© YES, 

Your El©ctronic Syst©ms GmbH z B©rlina Zachodni©go. Bądź nowoczesny! 

Dokładna informacja i aktualn© c©ny urządzeń 
pod niżej wymienionymi numerami telefonów. 


Gdynia 329391, 217088, 
Sopot 516921, 518274, 
Warszawa 196301 (APCO), 
Gliwice 321678 (INFOTECH) 
Katowice 647148 (ABM), 
Olsztyn 330762 (WARMDC), 
Kraków 229566, 341910, 

Łódź 360204, 526912, 
Bydgoszcz 224964, 

Wrocław 448164, 

Słupsk 36596, 

Zielona Góra 72288. 
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ZACHODNIO - 
NIEMIECKA 
FIRMA 


ELECTRONICS 

HAMBURG-BERLIN 

Za.pir3.sza. swoich Klientów 
do nowo otwartego 



w Berlinie Zachodnim. 

W programie naszym obecnie posiadamy: 

drukarki, plotery, digitizery, monitory, stacje dysków, twarde dyski, 
wszelkiego rodzaju materiały użytkowe, kserokopiarki, telexy, telefa- 
3 cy oraz TV Hi-Fi Video, komputery PC XT/AT/386 

Nasz adres; 

filia: 


OLECH Electronic GmbH 
Import-Export 
Johannisbollwerk 6-8 

2000 Hamburg 11 
West Germany 
Tel. (040) 31 13 48 
Tlx. 2166450 olex d 
Fax. (040) 31 22 24. 


Olech Electronic GmbH 
Import-Export 
Brandenburgische Str. 42 
1000 Berlin West 31 
Tel.(0-30) 89120 45 
Tbc. 18 68 87 olex d 
Fax. (0-30) 893 14 85 
Konto: 

Deutsche Bank AG Berlin 
BLZ 100 700 00 
Konto DM nr 940 39 65 
Konto USD nr 940 39 65 


Korespondencję prowadzimy w języku polskim. 


E LECTRONICS eXPORT 


P.O. Box 869 London W5, Anglia Tbc 94070505 ELEX G 
Tel: (0-0441)-993 7000. Sklep 19 Queens Paradę, London W5 


NOWOŚĆ - SPECJALNA PROMOCJA 
ATARI PC 3/XT OD 699 $ 

Prcx:esor 8088/2; 4,77/8 MHz; 640 K RAM; stacje dysków 360K 5,25”; porty sen^ i 
parallel; zegar; kalendarz; 5 gniazd kart; display Hercules, MDA, CGA, EGA; kla¬ 
wiatura 102 klawisze AT plus dodatkowo: mysz, programy (książki i dyski) 

GEM EGA STARTUP, GEM DESKTOP, GEM PAINT, GEM WRITE 
ATARI PC 3/XT2x360Kdrive 699$ 399 £ 

ATARI PC 3/XT lx360K + HD 20 MB 949$ 539 £ 

Posiadamy tylko niewielką ilość ATARI PC 3/XT po promocyjnych cenach, 
normalna cena sprzedaży (ale dodatkowo z MSDOS 3.21 i GW BASIC): 

ATARI PC 3 Z 2x360K 799$ 

ATARI PC 3 z lx360K + HD 20 MB 1049 $ 

Monitor mono amber 12” 149 $ 

Monitor mono amber 14” flat 178 $ 

Monitor kolor EGA 14” 479 $ 

Stacja dysków 5,25” 360K 100 $ 

ATARI ST 

520 STM + drive SF 354 (0,5MB) 399 $ 

520 STFM (1 MB drive) 489 $ 

1040 STFM (1 MB drive, TV mod.) 749 $ 

(z SOFTWARE VIP, MICROSOFT WRITE, SUPERBASE) 

Monitor mono SM 124 kupowany z ST 160 $ 

Monitor mono SM 124 178 $ 

Dysk sztywny 20 MB (z zasilaczem) 549 $ 

Stacja dysków 1 MB 3,5” 178 $ 

DRUKARKI 

PANASONIC KX-P1081 (9 igieł) 269 $ 

STAR LC-10 - MONO (9 igieł) 299 $ 


459 £ 
599 £ 
80 £ 
100 £ 
269 £ 
59 £ 


229 £ 
280 £ 
420 £ 

90 £ 
100 £ 
310 £ 
100 £ 


150 £ 
169 £ 


Co-18 328/05 


Do powyższych cen trzeba doliczyć 10 $ lub 5 £ na koszty FOB. Kopię wpłaty proszę wysłać U- 
stem poleconym na nasz adres wraz z zamówieniem. Podać zawód odbiorcy. Artykuły wysy¬ 
łane LOT-em z Londynu. Fracht opłaca odbiorca w złotówkach. Wysyłka ok. 2-3 tyg. od wpła¬ 
ty. Wszystkie artykuły posiadają gwarancję na części. 

Autoryzowany serwis ”UNICOMP” tel. Warszawa 554-554. 

Bliższe mformacje w katalogach na żądanie. ^ 15 / 307/04 



00-162 Warszawa 
ul. Dzielna 1 m. 5 
tel. 319-369 


TO DOSTAWY NIEZAWODNEGO SPRZĘTU 

inilcrokomput6ry: IBM PC XT/AT/386/PS-2; Amstrad 6128; 8256 

minikomputery: VAX; DEC; PDP 
drukarki, plotery, materiały eksploatacyjne 
instalacje sieci NpVELL 

obsługa gwarancyjna i pogwarancyjna - również sprzętu zakupionego w in 

nych firmach. 

Sprzęt VIDEO: magnetowidy, projektory, kamerowidy. 



POLSKA DOKUMENTACJA PC XT/AT 

• dBASE IV - pełny opis 

• TURBO PASCAL V. 4.0 

• CLIPPER 87 

• DOS 3.3/C; DOS 4.0 

• Drukarki Star; NX15, LCIO 

• STATGRAPfflCS 






SYSTEMY KOMPUTEROWE PC XT/AT 

OBSŁUGA BIURA HANDLU ZAGRANICZNEGO * UMEWAP’87 * 
K GOSPODARKA MATERIAŁOWA + PRZYRZĄDY POMIAROWE 
BIBLIOGRAFIA EUROGRAF - ATARI ST- STUDIO ARTYSTYCZNE 
"Prometeusz” - CAD-CAM - optymalizacja wykrojów 
”T-Komplex” - Zarządzanie Domami Towarowymi 


Co-17'324/05 
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TO SYSTEMY KOMPUTEROWE 

M renomowany sprzęt 
'M oprogramowanie użytkowe FK 
'M oprogramowanie specjalistyczne 
M licencjonowany serwis na cały kraj 
M instalacje i wdrożenia 
M komputerowy skład dla poligrafii 
polonizację komputerów i peryferii 
M materiały komputerowe 
M wydawnictwa i literatura 
zamówienia interwencyjne 

INSTALUJEMY KOMPLETNE STANOWISKA: 


U 

U 

U 


księgowości, kadr, plac, zarządzania i magazynów 
projektowania i inżynierii budowlanej 
telekomunikacji komputerowej 
pomiarowe pracujące w tle 
kartometrii komputerowej 


PKZ ”COMAX” 

01-121 Warszawa 
ul. Monte Cassino 13 
tel. 37-68-88, 37-80-38 
tlx 812417 


Oddział Północ 

81-305 Gdynia 
ul. Poznańska 1-3 
tel. 20-68-65 


Oddział Piła 

64-900 Pila 

ul. Słowackiego 13 

tel. 32-082 


Co-5273.03 



OMERS 

ELECTRONIC 


KOMPUTERY 

DRUKARKI 

Plotery 

Digitizery 

Elementy 


TEL. 19-43-91 
TLX 815917 ZEGWA 

XT • AT • 386 


STAR 



ROLAND 


"o 

li 


fi' 




WIELODOSTEP 


XENIX 


UL. ZAMOYSKIEGO 2 
03-801 WARSZAWA 



ELECTRO 


s 




Zakłady Produkcyjno-Usłuęrowe 

”WOLA” sp zoo 

(jednostka gospodarki uspołecznionej), 

00-726 Warszawa 36, box 40. ul. Willowa 8/10 
tel: 48-03-05, 49-56-66, tlx 816264 

Oddział w Toruniu: 

87-100 Toruń, ul. Rydygiera Id m.4, tel. 48-01-44 


Oferują do sprzedaży: 

Mikrokomputery IBM: 

PC/XT/AT/386 firmy Futurę Systems 
w dowolnej konfiguracji 

Urządzenia peryferyjne 
Sprzęt wideo 
Telefaxy 

Realizujemy zamówienia na wszelki specjalistyczny 
sprzęt elektroniczny i duże partie podzespołów. 
Udzielamy gwarancji, zapewniamy serwis pogwaran¬ 
cyjny i materiały eksploatacyjne. 
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PC 386 


może już minikomputer?!! 


COMBIT 

Przedsiębiorstwo 
Techniczno-Handlowe 
Spółka akcyjna 


PROKOM 

Innowacyjny Zakład 
Techniki Komputerowej 


Przedsiębiorstwo 

Badawczo-Produkcyjne 
i Handlowo-Usługowe 
Spółka z 0 . 0 . j.g.u. 


OFERUJEMY SPRAWDZONE, KOMPLEKSOWE ROZWIĄZANIA SPRZĘTOWO- 
PROGRAMOWE W TECHNOLOGII WIELODOSTĘPUI SIECI MIKROKOMPUTEROWEJ 


SYSTEM OPERACYJNY 

W PEŁNI 

ODPOWIADAJĄCY 

SCOKENK 


RELACYJNA BAZA DANYCH 

JĘZYK 

CZWARTEJ GENERACJI 


OPROGRAMOWANIE SIECIOWE 

W PEŁNI 

ODPOWIADAJĄCE 
XENIX - NET 


PODSYSTEM RACHUNKOWOŚCI FINANSOWEJ (FK-X) 

Plan kont. 

Ewidencja kont i dowodów księgoi^ch. 

Katalogi pracowników, kontrahentów. 

- moduł automatycznego rozliczania rozrachunków, 

- moduł automatycznego rozliczania kosztów, 

- moduł ewidencji materiałowej (EM-X). 

B. PODSYSTEM OBROTU MATERIAŁOWEGO (OM-X) 

Biiuro handlowe. 

Zaopatrzenie. 

Magazyny. 

- moduł zbytu, 

- moduł obsługi wydziału produkcyjnego, 

- moduł obsługi wydziału remontowego. 

C. PODSYSTEM KADROWO - PŁACOWY (w przygotowaniu) 

ZAPEWNIAMY W OPARCIU O ANALIZĘ POTRZEB: 

- kompletne instalacje mikrokomputerów dla potrzeb naszych systemów, 

- niezbędną rozbudowę wcześniej zakupionych instalacji mikrokomputerowych, 
gwarantującą poprawną instalację naszych systemów, 

- pełną integrację i współpracę naszych systemów, 

- pełne wdrożenie i oddanie do eksploatacji systemów, 

- realizację niestandardowych zamówień sprzętowo-programowych. 

Na życzenie Klienta udostępniamy listę użytkowników naszych systemów 


COMBIT S.A. 

uł. Gałczyńskiego 23 
40-587 KATOWICE 
teł. 5I2-9I4 


PROKOM 

ul. Balladyny 15a 
81-524 GDYNIA 
teł. 248-018, 216-677 
tlx 54535 prok 


MICON 

ul. Armii Czerwonej 83 
40-161 KATOWICE 
tel. 586 - 026 wewn.403 


Ko-108 256 03 
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Przedsiębiorstwo Zagraniczne KAREN 

ul.Obrońców 23, 

03-933 Warszawa 
tel. 17 84 10 
tlx 813948 kren pl 


Szanowny Panie Dyrektorze, 

Dziękujemy za zainteresowanie naszĘ firmą. 

Z przyjemnością informujemy, że możemy zaspokoić wszystkie potrzeby 
Pana Przedsiębiorstwa określone w skierowanym do nas zapytaniu. 

1. Oferujemy niezawodne i jednolite systemy komputerowe typu PC/XT/AT/386 

2. Instalujemy adaptery i oprogramowanie sieciowe ETHERNET. 

3. Do Zakładu Poligrafii polecamy zestaw ATARI ST DESKTOP PUBLISHING 
- bogato oprogramowany i oczywiście z polskimi literami. 

4. Do Klubu i Szkoły proponujemy ośmiobitowe ATARI XE. 

Proszę nie niepokoić się o "wsad dewizowy” - to wszystko jest za złotówki. 
Sprzęt objęty jest roczną gwarancją a przy odbiorze będzie mógł Pan uzupełnić 
swoje zbiory oprogramowania i literatury. 

Z poważaniem, 

DZIAŁ HANDLOWY 








MIKROS 


S-ka z 0.0 


30-319 Kraków 
Rynek Dębicki 6 
tel. (012) 66-91-22 


oferuje użytkownikom PC/XT/AT/ 386 : 
• VIDEO - STREAMER 

- Magnetowid + Sterownik = Streamer 

- 240 MB na zwykłej Video-kasecie 

- Rewelacyjnie niskie koszta 

- Po pracy zabierz Yideo do domu!!! 

SCO XEN1X 286/386 

istalacja, dokumentacja, szkolenie. 
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TESTER CYFROWYCH UKŁADÓW SCALONYCH 

niewielki, prosty w obsłudze 
sprawdza układy TTL i CMOS: 

74 - L, H, S, F. LS, AS, ALS, AC. ACT, C. HC, HCT, AHCT CD - 4xxx 
identyfikuje układy nieoz nacz one 

ZAKŁAD ELEKTRONIKI SPECJALISTYCZNEJ 

Hawajska 18 A 

^/ 1 łr'Dr\ 02-776 Warszawa 

MICRO R41 1?, Rfi 
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Antyradiacyjne filtry ochronne 

do monitorów 9”-28”, 
pochłaniają 98,9% promieniowania, 
redukują różnicę potencjałów do 0, 
testowane w Japonii, Kanadzie i USA, 

poleca 

Przedsiębiorstwo Usług i Wdrożeń Informatyki 
"Datacomp” S-ka z o.o. ul. ALliny 9, 31-416 Kraków 

’ * Ko-196/301/04 


membrany stykowe do klawiatur 
komputerów ZX SPECTRUM, 
ZX SPECTRUM + oraz QL. 

Cena jednej membrany 10 000 zł. 

jednocześnie 

produkcję dowolnych klawiatur foliowych 

(różnych zarówno pod względem funkcjonalnym 

jak i szaty graficznej) 

- na zlecenie Klientów. 

%ASZ. 
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wio sekund oprogramujesz kartę przetworników A/C i C/A 

gdy użyjesz kompilatora ACA. 

Wykonujemy dowolne oprogramowanie. 

Sprzętowe zabezpieczanie programów. 

Bliższe informacje przesyłamy pocztą. 

APARATURA ELEKTRONICZNA I PROGRAMY KOI^IPUTEROWE 

02-785 Warszawa ul. Koński Jar 2/42 
tel. 39 43 71 (wtorki, czwartki). 

KO-21S31B/0S 
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( OROHANUS O 

Zielona Góra ul. Licealna 6, tel. 44-46 
lub ul. Kożuchowska 16a, tel. 30-51. 

Ko-216/319/05 


COlMiyiODORE 

Programator Eprom 2716 - 27512 "Herkules 

Uniwersalny cartridge "Hercules” na EPROM-y o poj. 8 k 64 k 
z programem "karta Eprom". 

Oprogramowanie w języku polskim. 

Producent: Pracownia Elektroniki, 32-020 Wieliczka 

skr. poczt. 37, Śledziejowice 197. 


Ko-201/313/05 
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Pizedsiębiorstwo "Panda” działając z upoważnienia tirir.y FARCOM INC 

zakupiony wysyłkowo w tej firmie sprzęt, to jest: 

we PC XT/, AT, RT, 8-34 MHz! ^. 

crtable. laptop) 


r|!Sij{*i* X LTD. informuje, ż 

UUUf^ y - systemy komputGi 

ttW w dowolnej konfiguracji i wersji (standard, baby, iower 

pf X najlepszych firm światowych; 

y - urządzenia peryferyjne wszelkiego typu; 

^ - kserokopiarki i fotokopiarki wraz z materiałami eksploatacyjnymi; 
y - urządzenia do odbioru telewi^i satelitarnej 
^objęty jest serwisem technicznym naszego przedsiębiorstwa w ramach rocznej 
f gwarancji udzielanej przez FARCOM INC., LTD. 

♦Ś 

Przedsiębiorstwo "Panda” zapewnia: 

wykonanie przeglądu zerowego i testowanie sprzętu; 


f - wydanie użytkownikowi karty gwarancyjnej firmy FARCOM INC., LTD 
- wykonanie wszelkich zobowiązań z tytułu gwarancji; 
doradztwo techniczno-handlowe. 


Procedury dostępu 

do plików dBaselll i Clipper 
z poziomu Pascala Turbo 


NAPRAWA ZASILACZY 
do IBM XT/AT 

SP. RZEM. "CENTRUM” 


ZX SPECTRUM; T1MEX; ATARI 

programy użytkowe, edukacyjne, gry 
programy dla rzemiosła (receptury, kalkulacje, remanenty) 
informacje po nadesłaniu koperty zwrotnej ze znaczkiem 
wysyłka na cały kraj - rachunki 

”P.K.T.S.” Studio Komputerowe 

Warszawa, ul. Królewska 43 m.25 , 


Warszawa 

tel. 610 71 80, 49-28-12 


- U.I. R.Brykajło, 
Kraków tel. 55-31-00 wew. 10-22 


Ko-157/aB0»U4 


PRZEDSIĘBIORSTWO 

EXPORTU 
USŁUG TECHNICZNYCH 

Z5‘3B3 KIELCE 
ul. Wesoła 51 


monitor zielony, drukarkę ”DMP 
2000”, joystick, dyskietki z progra¬ 
mami oraz czyste, w komplecie 
sprzedam. 

Białystok, tel. 51-16-55 

Ko-206/315/05 


EXBUD- KIELCE 


SERWIS KOMPUTERÓW 


40-164 Katowice 
ul. Modrzewiowa 24/33 


do pracy w ośrodku informatycznym na nowoczesnym, oryginalnym sprzęcie IBM 
następujących pracowników: 

- informatyków 

- elektroników 

- projektantów systemów informatycznych. 

Przedsiębiorstwo oferuje ciekawą, atrakcyjną pracę, kontakty zagraniczne, konkurencyjne płace, mieszka 


poleca naprawy 


- COMMODORE 16, 116, +4, 
64, 128 

- ATARI 600, 800,65, 130XL/XE 

- DISC DRIYE 1641,1570, 

1571, 1050 

- MAGNETOFONY 
COMMODORE 

- DRUKARKI 
godz. 9-11 i 16-18. 


Oferty prosimy kierować do Działu Kadr tel. 411-31 wewn. 236 
lub zespołu d/s Informatyki tel. 31-28-33 wewn. 269. 


Ko-199/304/05 


Skontaktuj się z nami 
już dzisiaj... 

PRZEDSIĘBIORSTWO TECHNICZNO-HANDLOWE 
OBSŁUGI IMPORTU I EKSPORTU PANDA Sp ZOO 
40-320 KATOWICE UL 3 MAJA 23/7. TEL. 586633 

zadzwoń, napisz, przyjedź 
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OFERTA HANDLOWA 
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05-870 BŁONIE P-32 iil.PRZYBYSZ fl 20 TEL. 

OFERTA PRODUKCYJNA 


OPUS PC ni XT procesor V-20, 10 MHz, Ram 1 MB. karta 
'MULTIDISPLAY" (MGA+CGA+640x400), monitor bursztyno¬ 
wy 780x380 14”, klawiatura AT 102 przyciski, yjsilar?: 180 W, 
napędy dysków 2 x 360 KB lub 1 x 360 + 1 x 1.2 MB. interfejsy: 
CENTRONICS, CAME PORT, MYSZY, RS 232. 

OPUS PC V AT procesor 80286, 10 MHz, 0 WS 
(bez cykli oczekiwania), RAM 1 MB, pozostałe parametry jak 
OPUSPCmXT. 


1. VIP XT procesor 8088,10 MHz, RAM 1 MB, karta HERCULES, 
monitor bursztynowy 12 lub 14", klawiatura XT, zasilacz, CEN¬ 
TRONICS, RS 232, napędy dysków elastycznych. 

2. VIP AT procesor 80286,10 MHz, 0 WS, napędy dysków elastycz¬ 
nych, karta HERCULES, monitor bursztynowy, RS 232, zasilacz. 


1. ROLAND DXY880AA3/8 kolorów 

2. ROLAND DXY 980A A3/8 kolorow 

3. ROLAND DXY990AA3/fikcloiOw 
PLOTERY RCLAr.T) format Al. A2 



PC/IB1VI PC/XT/AT 

1. Karta prototypowa PC/XT/AT 

2. Karta 82551/0 PC 

3. Programator EPROM PCP-512 (2716 - 27512 Polski Edytor) 

4. Karta AC/CA 

5. Przedłużacz magistrali PM do XT/AT 

6. Karta RS 232 oraz inne 


554-554. TŁX.813276 UNICO PŁ 

OPROGRAMOWANIE 


, l^ore 
dooeni księgowy 


AST- AMORTYZACJA ŚRODKÓW TRWAŁYCH 
EPN- EWIDENCJA PRZEDMIOTÓW NIETRWAŁYCH 
EM- EWIDENCJA MATERIAŁOWA 


A 


Atari MECA ST 2 MB i mono monitor, drukarka laserowa SLM 804, 
dysk twardy 26 MB SH205 


:-.v 


TO-19-1(TYPVT52) 

(RS, Centronics, klawiatura. Neptun-156) Zapewma wielodostęp 
do IBM PC cena - 499.000 zl 

DO KAŻDEGO LABORATORIUM ELEKTRONICZNEGO 
niezawodny system uruchomieniowy (modułowy) 

UNISTS-80 

Obidowa modułowa rypu FC RAM 384 KB, FDD 360 KB, karta gra¬ 
fiki monochromatycznej, Centronics, klawiatura, monitor. 

Pakiet symulatora EPROM SYM 8 - 170.000 zł 

Pakiet programatora EPROM PCP 512 - 230.000 zł 

W komplecie do IBM PC - 380 000 zł 

irCHMIASTOWE TERMINY R EflŁIZACIl 

łóśkilibraćę —' 




Ant oryzowany serwis firmy 
ELECTRONICS EXPORT z LONDYNU 

lujurmujemy, że prowadzimy: 

- przeglądy zerowe 

- obshigę serwisową komputerów typu IBM PC/XT/AT 

• OPUSPC 

• VIP 

oraz ATARI ST 

ODPOWIADAMY NA WSZYSTKIE PYTANIA 
W SPRAWIE TYCH KOMPUTERÓW. 

Ko-185/182/01 
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HUKK Sp. z 0 . 0 . oraz AUTOR 

UHONOROWANEGO MIKROŁAUREM ’88 

PAKIETU TURBO-48 


MIKROS 


S-ka z 0 . 0 . 


30-319 Kraków I 

Rynek Dębicki 6 
tel. (012) 66-91-22 





ELEMENTY ELEKTRONICZNE 

- procesory, koprocesory, pamięci 

- układy scalone, podstawki 

- diody, tranzystory 

- złącza, izostaty, kable itp. 

Poszukujemy dostawców. 

Realizujemy zamówienia hurtowe 
i detaliczne. 







TURBO 


51 


W pełni zintegrowany pakiet uruchomieniowy dla mikrokompu¬ 
terów jednoukładowych rodziny MCS-51, pracujący na IBM/PC, 
łączący w jednym produkcie: 


cuyLur 


Ko-111/258/03 










DYSKIETKI 

FIRMOWE 


5 ( 


CENTÓW 


INFORMACJEBf/FKTNO/W/M 

TEL. 34-19-IOB KRAKÓW 


SUPER SOFTWARE 

Wykonuje oprogramowanie 
do komputerów 
typu IBM i innych. 

Dysponujemy szerokim zakresem 
usług, w tym między innymi: 

- księgowość, 

- kadry, 

- symiiacje komputerowe, 

- różnego rodzaje bazy da¬ 
nych, 

- programy specjalistyczne. 

ul. Obopólna 4/2, 

Kraków 30-069 


- kompilator 

- symulator 

- debugger symboliczny 

Pełna symulacja pracy procesora i jego środowiska zew 
nętrznego zapewnia komfort i wysoką efektywność pra¬ 
cy projektanta. 





tel. 37-72-53 


D48 - deasembler dla procesorów z rodziny MCS-48 
D51 - deasembler dla procesorów z rodziny MCS-51 

W opracowaniu atrakcyjne, zupełnie nowe produkty dla mi¬ 
kroprocesorów jednoukładowych. 

Wersję demonstracyjną TURBO-Sl wysyłamy po otrzymaniu 
dowodu wpłaty na nasze konto PKO BP V O. W-wa nr 1557- 
-188665-136 kwoty 6.000 zł 

HUKK Sp. z 0 . 0 . 

02-384 Warszawa, 
ul. Włodarzewska 75, 
tel. 22-40-06. 
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PROFESJONALNE STANOWISKA ROBOCZE 
KOMPUTEROWEGO WSPOMAGANIA PROJEKTOWANIA 

oraz najpopularniejszy na swiecie profesjonalny system 


AUTOCAD* 

opROGRA^owJfNS?europejskich i amerykańskich 


AutoCAD® 


n • ‘^^stalacje kompletnych stanowisk roboczych APLICAD 2000; 

n Centrum Szkoleniowe AutoCAD-a!; • komputery w standardzie IBM PC XT AT/386‘ 

- Adaptacje systemu do potrzeb użytkownika; • karty ARIST" firmy CONTROL SYSTEMS; monitory NEC 

Instalacje sieciowe systemu AutoCAD” • stacje graficzne firmy CAMBRIDGE COMPUTER GRAPHICS- 

oprogramowanie specjalistyczne # peryferia firmy HOUSTON INSTRUMENT: 

- plotery DIN-A4 - DIN-AO : najnowszej serii EDMP-60™, 

- digityzery A4 - AO :III-PAD Plus 9000 TM, TrueOndSOOO™, 

- scaner SCAN-CAD 128A'^''^, z oprogramowaniem III-SCAN™ 

■^'^^o^yzo’waii'y pYzez pYodiicentów^ soirwis gwaYancyiuy i poo^waYancyiny! 
***^01VIOC-yjNE CENY NA SPRZĘT NAJNOWSZEJ GENERACJI! 
Przedsiębiorstwo Produkcyjno-Handlowe Zastosowań Informatyki 

APŁIKOiyi Sp.z 0 . 0 . 

91-335 Łódź, ul.Łimanowskiego 129, tel. (0-42) 34-39-32 
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lYiiKromaiKei 


InIer/Ims 

BIURO 

HANDLU 

ZAGRANICZNEGO 



00-867 WARSZAWA 
ul. Chłodna 35/37 
tel. 24-78-16 
24-78-17, 24-78-23 
tbc 81 56 24 


INTERAMS 


OFERUJE: 


Nowe możliwości zakupu dla przedsiębiorstw 
Sprzęt komputerowy i aparatura pomiarowa 
za waluty wymienialne. 

Kompleksowy zestaw usług przy zawieraniu kontraktów zagranicznych. 
Natychmiastowe dostawy sprzętu ze składu celnego. 

Badanie zagranicznego rynku komputerowego i doradztwo przy zakupie sprzętu. 
Oprogramowanie. 

Niskie ceny. 

PROWIZJA za usługi Biura Handlu Zagranicznego płatna w złotówkach 


WPHW Dąbrowa Górnicza 


SKLEP Nr 163 41-300 DĄBROWA GÓRNICZA, ul. Sobieskiego 17 

tel. 622 371 w godz. 10 - 18 

tujl 

mikrokomputery 8-bitowe 

(Amstrad, Commodore, Atari) 

mikrokomputery klasy IBM XT/AT 
urządzenia peryferyjne 

(drukarki, plotery, stacje dysków) 

akcesoria i materiały eksploatacyjne 

(dyskietki, kable, kasety barwiące, pudełka,...) 

sprzęt video i CTV 
sprzęt elektroakustyczny klasy Hi-Fi 
sprzęt estradowy 

drobny sprzęt elektroniczny i gospodarstwa domowego 

SKLEP PROWADZI SPRZEDAŻ POZARYNKOWĄ 
PROWADZIMY KOMIS I SKUP w/w ARTYKUŁÓW 

W TYM ROKU o 5% TANIEJ! 

SERWIS 12-MIESIĘCZNY PROWADZI: 

PRZEDSIĘBIORSTWO 
POSTĘPU TECHNICZNEGO 

SPÓŁKA z 0.0. 

41-303 DĄBROWA GÓRNICZA 
Czerwonych Sztandarów 94 

tel. 647 148 tbc. 031 28 98 ko-hmizos 


Agencja Informatyczna 

”BETAi8” 

41-200 Sosnowiec skrytka P-254 
tel. 632-935, 631-770 


również wysyłkowo - pocztą 
programy, instrukcje, 
opisy i schematy 
technicznych udoskonaleń 
komputerów: 
ACORN, AMSTRAD, 
ATARI, COMMODORE, 
IBM, SHARP. Ko-2a/310/05 


- programator pamięci 
UV/E EPROM dla PC XT/AT 

wyposażenie programatora: 

PMJ48 - programator EPROM 

procesorów typu 8741/42/48/49 
PMJ51 - programator EPROM pro¬ 
cesorów typu 8744/51/52 
SPE32 - symulator pamięci 2716/32 
SPE256- symulator pamięci 
2716/32/64/128/256 

Producent: 

Zakład Komputerowych 
Systemów Pomiarowych 


99 


99 


ul. Zbyszka z Bogdańca 4, 
80-419 Gdańsk, tel. 41-95-19 
Wysyłamy ulotki mformacyjne. 
Gwarancja 12 mies. 

Serwis pogwarancyjny. 


Ko 63 32105 
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Firma oferuje sprzęt komputerowy klasy 
IB]VI PC, AMSTRAD. 
Pirogra.m Karta, drogowa 
Dokumentację w języku polskim 


do komputerów IBI^: 


Uwaga Wirus (jak ustrzec się wirusów) 

Przewodnik programisty IBM 
Wprowadzenie do komputerów IBM 
Framework IIp 
System operacyjny DOS 3.3 
System operacyjny DOS 4.0 
GW-Basic kompiliior 
Programowanie w GW-Basic 
Turbo Basic 1.0 

Turbo ”C” (200 atrakcyjnych procedur) 

Aztec ”C” 

Język ”C’’ dla zaawansowanych 

T^bo Graphic 

Turbo Debuger 

Turbo Assembler 

Turbo Pascal wersja 5.0 

Turbo Database Toolbox 

Grafika Turbo Pascala 4.0 i Turbo C 1.5 

Metody numeryczne do Turbo Pascala 4.0/5.0 

Turbo Power Tools (procedury do Turbo Pascala 4/5- 

Procedury numeryczne do Fortranu SSP/PC 

Przewodnik zaawansowanego programisty do dBase n/III 

dBase HI poradnik encyklopedyczny 

dBase ni-ł- programowanie 

dBase in-i- zastosowania 

dBase HU- poznawanie 

dBase in-»- opis pakietu sieciowego 

dBase ni-ł- instalacja 

dBase Ill-ł- generator aplikacji 

dBase IV (Co nowego dBase IV) 

Clipper 87, kompilator do dBase III+ 

Praktyka programowania w Cliperze 

FoxBase-ł- 

Eureka 

PC Tools De Lux 
Stat Graphics 

Programowame w Assemblerze 
Instrukcja obsługi PC 1512 
Chi-n Writer / Wordstar 
Wordstar 2000 

Instrukcja do drukarki NX-15 
Norton CommcUider 87 
Or-Cad 

Opis systemu OS-2 
Novell - podręcznik użytkownika 
Novell - podręcznik instalatora 
Instalacja karty 3 Com Etherlink 
Instalacja karty Arcnet 


- 1.200 zl 

- 60.000 zł 

- 18.000 zł 

- 70.000 zł 
80.000 zł 

- 85.000 zł 

- 35.000 zł 

- 50.000 zl 

- 70.000 zł 

- 65.000 zł 

- 60.000 zł 

- 70.000 zł 

- 25.000 zl 

- 50.000 zł 

- 50.000 zł 

Of\ _t 

- OU.UUU Zl 

- 12.000 zł 

- 55.000 zł 

- 60.000 zl 
65.000 zł 

- 50.000 zł 

- 40.000 zł 

- 50.000 zł 

- 30.000 zł 

- 40.000 zł 
-30.000 zł 

- 20.000 zł 

- 10.000 zł 
- 8.000 zł 

- 50.000 zł 

- 85.000 zł 

- 50.000 zł 

- 65.000 zł 

- 45.000 zł 

- 16.000 zł 

- 65.000 zł 

- 60.000 zł 

- 35.000 zł 

- 10.000 zł 

- 30.000 zł 

- 20.000 zł 

- 20.000 zł 

- 95.000 zł 

- 75.000 zł 

- 90.000 zł 

- 60.000 zł 

- 50.000 zł 

- 50.000 zł 


POLONUS, spolszczona wersja dBase ni+, kompunikaty, sortowanie i indeksowanie po pols¬ 
ku (kody Mazovii), CGA lub Hercules, 3 dysk., 322str. instr _ 210.000 zł 

CLIPPER SARMATA 87, spolszczona wersja kompilatora do POLONUSA, 463 str., instr. 3 

- 230.000 zł 

FIUIMEWORK IIp, pakiet zintegrowany, polskie litery (kody Mazovii) wymienność progra¬ 
mów z POLONUSem, CGA, EGA lub Hercules, 4 dysk., 314 str., inst - 140 000 zł 

DRUKARZ, program pomocniczy do generacji wydruków, także specjalna wersja do progra¬ 
mu FRAMEWORK IIp, 1 dyskietka, 27 str., instr _ 35.000 zł 

ELEKDRUK, spolszczona wersja programu Smartwork, projektowanie prostych płyterk dru¬ 
kowanych, praca tylko na CGA, 1 dyskietka. 41 str., instr - 20.000 zł 

WYKRES, spolszczona wersja programu MS Chart, możliwość wykonywania profesjonalnych 
wykresów i zestawień, CGA lub Hercules, 2 dyskietki, 411 str., instr - 150.000 zł 

PISMAK, polski edytor tekstu, znaczme szybszy od Chi- Writera - 200.000 zł 


Zniżka. 10% 

przy płatności czekiem lub gotówką 

Firma posiada uprawnienia do prowadzenia 
handlu zagranicznego. 


00-443 Warszawa, 

ul. Górnośląska 9/11 

telefon 21-56-08, 28-62-94, telex 817245 


aD'i?aDoo(?'i?..... 

00-443 WARSZAWA, ul. Górnośląska 9/11 
TEL. 21-56-08 lub 28-67-94 TLX 817245 


OFERUJEMY WYSOKIEJ KLASY 
SPRZĘT ELEKTRONICZNY 
PRODUKCJI KRAJOWEJ: 


1. Terminal UZ 19-1 (emulacja VT 52 i Z-19), Neptun, RS232, 
klawiatura; 

2. Terminal UZ 19-1, RS232, Centronics, klawiatura; 

3. Terminal komputerowy TK-52 (bez monitora i klawiatury): 

4. Karta RS232 x 8 kanałów; 

5. Karta RS232 x 4 kanały; 

6. Karta RS232 x 2 kanały; 

7. Karta RS232 x 1 kanał; 

8. Karta 8255 PC, 2 porty 8255, 1 układ czasowy 8253; 

9. Karta prototypowa PC, duża, szyna wstępnie buforowana; 

10. Programator EPROM PCP-512 z polskim edytorem, pamięci 
2732A, 2764, 2764A, 27128, 27256, 27512; 

11. Programator PMJ-48, pamięci 8741, 8762, 8748, 8749; 




ł^iuyieuuaiui rmj-oi, i^aiiuęCl ”^44, 0/51, 0752, 


V 


cena: 

Centronics, 
499.000.- 
419.000.- 
600.000.- 
699.000.- 
399.000.- 
129.000.- 
99.000.- 
149.000.- 
99.000.- 
2716. 2732, 
299.000.- 
130.000.- 
149.000.- 

13. Programator EW-883. pamięci 2716, 2732, 2764, 27128, 27256, 27512 i mikro¬ 
komputery jednoukładowe; 600.000.- 

14. Programator PCPE-512/200, pamięci 2516,2532,2564,2716,2732.2732A. 2764, 

2764A, 27128, 27128A, 27256, 27256A, 27512. (2816, 2864, 2916); 382.000.- 

15. Programator - emulator "PREMUL”. pamięci 2716, 2732, 2764, 27128, 27256, 

27512; 1.380.000.- 

16. Emulator - programator ”EMU” pamięci stałych 2 kB. 4 kB, 8 kB. 16 kB. assem¬ 
bler procesorów 8085,8084,8022, Z-80. F8/P70,6800, możHwość przeglądania 
pamięci w kodzie heksadecymalnym, wybranym mnemoniku lub formacie 
Ascn - terminy i pozostałe warunki do dalszego uzgodnienia; 

17^Symulator SME-8, pamięci 2716, 2732, 2764; 199.000.- 

18. Symulator SPE-256. pamięci 27256, 27128, 2764, 2732, 2716; 438.000.- 

19. SymulatorSPE-32. pamięci 2732, 2516; 140.000.- 

20. Zestaw głośnikowy ”INGLO” do odtwarzania mowy i efektów dźwiękowych, 

do IBM PC; 295.000.- 

21. Plotter A3 DATAX 87, 150 mm/s; 2.480.000.- 

22. Komputerowy interfejs teleksowy ITS-2000, świadectwo homologacji Instytu¬ 
tu Łączności, do IBM PC; 1.500.000.- 

23. Zasilaczprzeciwzanikowy ,PUP-300, moc300 W; 1.280.000.- 

24. Konwerter M-20/60 (możliwość współpracy urządzeń przez łącze RS232 na 

znacznych odległościach); 74.000.- 

25. Rozdzielacz przeciwzakłóceniowy ACAR - - wielogniazdowy przedłużacz 

sieciowy z filtrem przeciwzakłóceniowym i zabezpieczeniami przepięciowy- 
nii: 38.000.- 

26. Pokrowce (na klawiaturę, komputer, monitor - - komplet); 65.000.- 

27. Automatyka przemysłowa - regulatory temperatury ciągłe, dwustawne, kro¬ 
kowe - - P, PI, PID (III kw. 89); 100.000 - 450.000.- 

28. Urządzenie "sztuczny pacjent” do sprawdzania prawidłowości zapisu EKG; 

. 49.000.- 

29. Elektroniczne mierniki temperatury (przenośne i stacjonarne) - terminy i po¬ 
zostałe warunki do dalszego uzgodnienia; 

30. Cyfrowe woltomierze tablicowe - terminy i pozostałe warunki do dalszych 
uzgodnień; 

31. Czujniki temperatury - terminy i pozostćde warunki do dalszych uzgod¬ 
nień. 

32. Autonomiczny tester cyfrowy układów scalonych TTL i CMOS 68.000.- 

33. Inteligentny bufor drukarski (podłączenie z komputerów IBM oraz 3 druka¬ 
rek) zawiera pamięć RAM: 

-256 KB 1.900.000.- 

- 512 KB 2.500.00.- 


Ko-5a'300/04 


ZAPRASZAMY DO WSPÓŁPRACY 

PRODUCENTÓW 
ATRAKCYJNYCH URZĄDZEŃ 


Co-16/323 



56 COmPUEE^ 































Mikromarket 


/T 



NOWE FORMY 
WSPÓŁPRACY 
przy zakupach sprzętu 
komputerowego, kontrolno-pomiarowego, 

I urządzeń peryferyjnych i oprogramowania: 

łf znaczne obniżki cen sprzętu nawet do połowy ceny rynkowej przy zamówieniach długoterminowych 
fachowa i szybka realizacja Waszych zakupów dewizowych 

oferujemy korzystne dostawy sprzętu komputerowego w zamian za atrakcyjne towary i usługi na eksport 
łł odkupimy niewykorzystany odpis dewizowy - oferujemy łepsze warunki niż na przetargach dewizowych 
dostarczamy pojedyncze egzemplarze - prowadzimy informatyzację całych przedsiębiorstw i instytucji 
obejmujemy posiadany już sprzęt serwisem pogwarancyjnym _ 


s ka Z aa 


Co-4/269/03 


, - - - 


Wojewódzkie 

Przedsiębiorstwo 

Handlu 

Wewnętrznego 
Oddział 
w Tychach 



43-100 Tychy, Al. ZMP 77 

tel. 27-69-75 


IDEOBIT 


poleca. xn.ięd2v innymi 

• sprzęt komputerowy 

Atari • Commodore • Amstrad # IBM PC XT/AT/PS-2 

• drukarki STAR, EPSON, AMSTRAD 

• sprzęt audiowizualny 

magnetowidy • OTV PAL/SECAM • wideoskopy • kamery 

• anteny satelitarne 

• aparaturę badawczo-naukową 

Udzielamy gwarancji, prowadzimy naprawy pogwarancyjne 

Za.pewniamy o atrakcyjnycłi cenacłi. 


irSńoićonf? 


0 . 0 . 


Ko-76/236/01 
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dialog 

Przedsiębiorstwo Zagraniczne 


Marconi 

Instruments service 



^ STEROWNIKI MIKROPROCESOROWE 

W OBUDOWIE BIUROWEJ LUB EUROKASECIE 
PRZETWORNIKI, INTERFEJSY, PAKIETY NA ZAMÓWIENIE 
^ OPROGRAMOWANIE SPECJALISTYCZNE 
KOMPUTERY IBM PC XT/ATI STEROWNIKÓW 
standardowe i na zamówienie 

KADRY - PŁACE - FINANSE - KSIĘGOWOŚĆ - MAGAZYNY 

^ INFORMATOR TECHNICZNY WYSYŁAMY BEZPŁATNIE 












96-313 Jaktorów, Chylice 5 
woj. skierniewickie 
tlx 886 861 ug pl 



r ^ r ^ ^ ^ 
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PRO 

INFO 


Adres: Przedsiębiorstwo 
"PRO-INFO” 
ul. Sikorskiego 18/38 
40-001 Katowice 
skrytka pocztowa 1347 
tel. 53-42-88 



Oryginalna dokumentacja 
w języku angielskim 
na IBM PC XT/AT 


Word Perfect 5.0; Ouatro 1.0; Turbo Pascal 5.0 
Turbo C 2.0; Turbo Assembler 1.0; Turbo Debuger 1.0 


XEN1X - 
Wkrótce: 


w języku polskim 

podręcznik dla progranustów i operatorów 
10 tomów, 700 stron. 


• podstawowa dokumentacja do dBase IV 

• podstawowa dokumentacja Clipper’88 

• zbiorcze opracowanie nt. baz danych. 

oraz programy użytkowe: 

- KATALO(Tkartote5a silników elektrycznych 

- ZBYT kalkulacja, fakturowanie i rozliczanie sprzedaży 

- PROJEKT ewidencja twórców i projektów racjonalizatorskich 

- ANALIZA analiza awaryjności i niezawodności wyrobów. 

Ko-24/303K)4 


TOWARZYSTWO 


NAUKOWE 


8 p . Z O . O 

xii-839 WARSZAWA ul. Barricka 30 

telefon; 641-61-88 


^ Ekspertyzy, projekty, 
nadzór, rozruch 

procesów przemysłu spo¬ 
żywczego, chemicznego, 
farmaceutycznego oraz 
ochrony środowiska. 

'I: Usługi informatyczne 

transfer plików, projek¬ 
towanie, pielęgnacja i 
ochrona systemów, kon¬ 
sultacje, programy inży¬ 
nierskie narzędziowe i 
firmowe. 

$ Systemy pomiarowe 
$ Automatyzacja 

procesów technologicz¬ 
nych i eksperymentów 
laboratoryjnych. 


^ Telefax Canon 
FAX230 
t Emulatory 

INTEL 8048/4918051/52 

^ Sprzęt komputerowy 
XT/AT/386/PS 2 

oraz urządzenia peryferyjne. 

$ Pokrowce i materiały 
ekspłoatacyjne. 

$ Sprzęt audio-video 
$ Sprzęt nietypowy 

dowolny sprzęt elektro¬ 
niczny i podzespoły. 

$ Tachomerty 
$ Dzierżawa sprzętu 


Prowadzimy szkolenie, 

zapewniamy serwis gwarancyjny i pogwarancyjny 
oraz dostawy do miejsca zainstalowania. 


r^i IDI I ® MODUŁOWE SYSTEMY ^ 

^ STEROWANIA I POMIARÓW 

sp. z 0 . 0 . Janusz i Krzysztof Kamińscy 

01-152 Warszawa, ul. Lumumby 1Ó/27 @ 32 65 51 

MIKROKOMPUTER JEDNOPŁYTKOWY 

GDM-ZSBC 










n 
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autonomiczne sterowniki przyrządów pomiarowych 
systemy zbierania danych 
sekwencyjne sterowniki przemysłowe 
rozproszone sieci stanowisk pomiarowych 
dydaktyka 

a.ii.e tecłiniczne: 

procesor Z80-H (8MHz) 

pamięć EPROM 32kB, RAM 64kB, podtrzymywanie bateryjne 
układ przerwań (8259A) 
trzy liczniki impulsów (8253) 
układ czuwający (watch-dog) 

48 programowanych we/wy TTL (2x8255A) 
interfejs szeregowy RS232C (8251A) 

8 wejść i 4 wyjścia analogowe 

standard podwójnej EUROKARTY (160x233mm), magistrala 
BUSMATII 

bogaty wybór kart dodatkowych 

pro 9 ra.ino wanie: 

system operacyjny CP/M w pamięci EPROM 
monitor-debugger w pamięci EPROM 

zestaw narzędzi do tworzenia oprogramowania na komputerach PC 
XT/AT lub komputerach CP/M 

zdalny debugger pracujący na PC XT/AT lub komputerze CP/M do¬ 
łączony przez interfejs do GDM-ZSBC, pozwalający na przesyłanie 
i zdalne uruchamianie programów w GDM-ZSBC. 

Ko-219'320/05 


TURBO PASCAL 5.0 

(750 str.) po polsku, 

orazTURBOC2.0, 
TURBO ASSUiyTRTiFIIł 1,0 iinne 


Kraków, ul. Langiewicza 10/3, 
tel. 43 39 57. 


Ko-212/317/05 


Polska dokumentacja 

do programów komputerowych 
na IBM PC/XT/AT. 

PLJ Sp. z O.O., 

ul. Skoczylasa 8 m. 167, 
03-470 Warszawa, 
tel. 19-78-62 

KO-2J0 316 05 


Ko-126'267-03 


Przedsiębiorstwo Automatyzacji i Komputeryzacji 

"AUTOKOMP” Sp. z 0.0. 

Jednostka Innowacyjno-Wdrożeniowa nr 037-15/87 

Ofeznje do sprzeda.ż-y': 

KONWERTOR KR-1 

Zwiększa zasięg transmisji szeregowej do ok. 2500 m 
przy szybkości 19,2 kb. 

Cena 1 szt.: 298.000 zł. dla zamówień do 30.06.1989. 

Zamówienia przyjmuje i udziela informacji: 

BIURO HANDLOWE; 

ul. M. Buczka, 70-423 Szczecin 
tel. 37-032, 44-125; tlx 425767 auc pl. 

Ko-231-326/05 
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Pragniesz postei3u na stanomsKu piacu ? 


Potr zepniesz nlezauodnego opiogianonania ? 


SzuKasz netod optynallzacji u dzledzlnacP: 


płace,Kadig, 


gospodaiKa 

naterlałona ? 


Chcesz Kupie sprzęt 





Ko-55 01 


rnkro 


31-456 Kraków 
ul. Ugorek 18/23 
tel. 11 51 07 


I i oDroaramowania LAN 


Serwis mikrokomputerów PC XT/AT 

- gwarancyjny i pogwarancyjny, 

Zabezpieczenia zasilania komputerów 

- stabilizatory, filtry, zasilanie awaryjne. 

Projektowanie i wdrażanie systemów 

- analizy, koncepcje, konsultacje. 


Ko-32/219^01 





ml 

81-056 Gdyiua, ul. Helska 14, tel. 23-37-40, tbc 054561 mg pl 

OFICJALNY DYSTRYBUTOR 
SPRZĘTU KOMPUTEROWEGO FIRMY 
HEWLETT-PACKARD 
W POLSCE 

System PL-DRUK uhonorowany nagrodą I stopnia na 
O.T.O. SOFTARG’88 w połączeniu z wysokiej klasy 
sprzętem firmy 'Hewlett-Packard zapewni Twojemu 
przedsiębiorstwu samodzielne przygotowanie i wyda¬ 
wanie dowolnych publikacji. 

OFERUJEMY 

PL-DRUK - pierwszy polski system Desktop Pu- 
blishing umożliwiający skład w języku polskim, 
rosyjskim i angielsfóm, z wykorzystaniem poli¬ 
graficznych krojów pism. 

Sprzęt komputerowy do prowadzenia działalności 
wydawniczej: 

- komputery, 

- drukarki laserowe, 

- skanery, 

- monitory całostronicowe. 

Dostarczamy sprzęt kompu¬ 


terowy firmy Hewlett-Pac¬ 
kard zarówno za złotówki, 
jaki za waluty wymienialne. 



HEWLETT 

PACKARD 


Ko-145 272 03 
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Mikromajrket 


Producent S O FTL.AN^ 


Dystrybutor 


60-288 POZNAŃ ul. OBRONNA 8 
tel. 676271, 663024 w. 216 

KOMPUTEROWY 
INTERFEJS TELEKSOWY 

ITS-2000 


>S()r I LAN 



ITS-2000 



WYRÓŻNIENIE SOFTARG’88 
MEDAL MIKROLAUR’89 

- zastępuje tradycyjny dalekopis 

- automatycznie zestawia połączenia 

- automatwznie odbiera I nadaje Informacje 

- pracuje 24 godz. na dobę 

- posiada własny edytor tekstowy 

- zawiera podręczny bank numerów 

DOŁĄCZY TWÓJ KOMPUTER 
DO ŚWIATOWEJ SIECI TELEKSOWEJ 

^EST INSTYTUTU ŁĄCZNOŚCI 


MICRONET 


ZAKŁADY ELEKTRONICZNE 

“MICRONET” 

81-836 Sopot, ul. Krasickiego 9 
tel. 51-13-lZ, tlx 051-2876 


oferują 

TERMINAL MT-220 

funkcjonaliue zgodny z terminalem VT220 firmy DEC 


MT-220 - 
MT-220 - 

MT-220 - 


MT-220 

MT-220 

MT-220 

MT-220 


emiduje terminale yT52, YTIOO, VT200 oraz PC-Shadow 
posiada możliwość współpracy z dowolną drukarką 
wyposażoną w złącze równoległe lub szeregowe 
może być stosowany w zestawach mikrokomputerowych (np: 
IBM PC/XT, IBM PC/AT), jak również jako końcówka do więk¬ 
szych maszyn (np: SM-3. SM-4, SM-5, PDP-Il, MERA 400) 

• tryb VT52, VTI00, VT200 polecany do pracy pod kontrolą 
systemów operacyjnych XENIX. UNIX, 0NX, RSX, RT-11, 

• tryb PC-Shadow zlecany do pracy pod kontrolą systemu 
typu MultiLink, PC-MOS 

umożliwia wybór emulowanego terminala oraz parametrów 
jego pracy w prosty sposób przez samego użytkownika 
sprzedawany jest w zestawie: monitor monochromatyczny z 
poświatą bursztynową i klawiaturą typu IBM PC/AT produkcji 
zachodniej 

wyróżnia spośród innych konstrukcji tego typu spotykanych w 
Polsce wysoka jakość obrazu oraz niska cena. 
to konstrukcja oparta na własnych rozwiązaniach technicz¬ 
nych i sprawdzona w dwuletniej eksploatacji 

ZAPRASZAMY 


Ko-193/302/04 


OA-ŁINK! 

ODRADZAMY ZAKUP MIKROKOMPUTERÓW 

wszystkim, którzy mają już przynajmniej jeden mikrokomputer, a inne chcieliby zainstalo¬ 
wać gdzieś blisko niego. 

Dużo lepszyrn i tańszym sposobem jest dokupienie stanowisk pracy w systemie OA-LINK, 
z ^órych każde pod względem funkcjonalnym odpowiada mikrokomputerowi XT, ale z 
większą pamięcią (704 K) i dostępem do wspólnych twardych dysków i innych peryferii. 


OA-ŁINK to nowoczesny system, który daje użytkownikowi mi¬ 
krokomputerów nowe stanowiska pracy i eliminuje koszty zwią¬ 
zane z łączeniem ich w sieć. 


Realizujemy również połączenia centralnego komputera systemu OA-LINK w sieć z dużymi komputerami (IBM 
360/370, RIAD itp.) 

Oferujemy także inny sprzęt standardu IBM PC oraz: 

drukarki ALPS (typu heayy-duty, 5 lat pracy bez awarii) 
dyski elastyczne wielkiej pojemności (6 - 20 MB) 

karty do bardzo szybkich obliczeń numerycznych (procesor 32-bitowy, 25 MHz, 16 MB) 

OPROGRAMOWANIE - szczególnie polecamy SART - system automatycznego rozli¬ 
czania transportu. 

Biuro Techniczno-Handlowe Warszawa, 

ul. Waliców 19/20 tel. 24-26-59 tbc. 852729 

Zakład Produkcyjno-Serwisowy: 

Warszawa-Anin ul. Stradomska 46 iK^ezwoi 
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INTELIGENTNY BUFOR DRUKARKI 

• jeden komputer - kilka drukarek 

• jedna drukarka - kilka komputerów 

• łącza RS232C i CENTRONICS 

• 512 kB pamięci 

EMULATOR PAMIĘCI EPROM 

2716-27512 

profesjonalne oprogramowanie sterujące dla mikro¬ 
komputera PC XT/AT 

TESTER UKŁADÓW SCALONYCH 

0 a.utoma.tyczriG rozpoznawaniG i tGstowaniG układów TTL 

i CMOS 

• urzĘ.dzGnia autonomiczriG lub karta do mikrokomputGra 
PC XT/AT 

PROJEKTOWANIE STEROWNIKÓW 
MIKROPROCESOROWYCH 


Laboratoria Techniki Mikrokomputerowej 
00-961 Warszawa 42, skr. poczt. 83 


Dystrybutor: INTERSOFT Sp. z o.o. 

ul. Górnośląska 9/11 
tel. 21-56-08, 28-67-94 
tlx 81-72-45 


Ko-13/282/04 
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To nowoczesne i niezawodne oprogramowanie! 

To duże osiągnięcia w zakresie komputeryzacji [dac! 

(medal na Ogólnopolskich Targach Oprogramowania SOFTARG’88) 
To solidny dostawca profesjonalnego sprzętu komputerowego! 


Przedsiębiorstwo Systemów Komputerowych 

i Usług Informatycznych 


-eeMPu^soFT spóii^ 


oferuje Państwu 

Dostawy, instalacje i serwis mikrokomputerów zgodnych z IBM PC/XT/AT/ 
386. 

Urządzenia peryferyjne komputerów: drukarki, plotery, digitizery, dyski 
itp. 

Obsługę informatyczną zjazdów, konferencji, imprez. 


Zakład Ushig Informatycznych COMPU-SOFT 

przedstawia Państwu: 


• System Wspomagama Administracyjnego - nagrodzone oprogramowame 
płacowe, które nie boi się zmian przepisów lub nowych wymogów użytko¬ 
wnika. 

• System Kadrowy "Info-Bank" - to dużo więcej niż ewidencja osobowa! 

• Ekranowy Symulator Pracy Drukarki - całkowita nowość, oszczędność pa¬ 
pieru! 

• "Izolinie” - program lub moduł do zaimplementowania we własnym progra¬ 
mie! 


41-814 ZABRZE iiL Rosenbergów 4 teł. 72-37-62 


^Komputera i oprogramowania 
w jednej Hrmie - to rozsądna decyzja! 


Firma 

]V1UEŁ 

oferuje do sprzedaży: 

1. Interfejs do ZX Spectram, ZX Spectrum Plus, 
Timex 2048, umożliwiający współpracę z czterema 
napędami dysków elastycznych, RAM-dyskiem, 
dowolną drukarką graficzną, maszyną do pisania 
Robotron S-6120, monitorem ekranowym, rozszerza¬ 
jący Basic oraz system operacyjny ZX Spectrum. 

Nie zajmuje pamięci RAM!!! 

2. Sterowany ikonami programator Eprom 2716-27256 
do ZX Spectrum. 

3. Przeróbkę drukarki DZM 180 na drukarkę graficzną. 

4. TURBO 2000F do ATARI! 


Informacja: 
Korespondencj a: 

Zamówienia: 


Wykonawca: 


tel: 33-40-91 

MUEL ul. Cząstkowska 30, 
01-678 Warszawa 
Spółdzielnia Rzemieślnicza 
Specjalistyczna Elektryków, 
ul. Grójecka 128, 

02-383 Warszawa 
MUEL. 


Ko-6/309/05 


Przedsiębiorstwo Zastosowań Informatyki 


Medi - Tronik sp. z 


O.O. 


Ko-9/237/Ol 


Posiada w sprzedaży: 

szereg programów aplikacyjnych w różnych 
dziedzinach gospodarki (na życzenie wysyłamy katalog) 

1^ Oferuje: 

• kartę procesora komunikacyjnego dla mikrokomputerów 
zgodnych z IBM PC/AT (8 terminali w systemie SCO Xenix), 

• emulator procesora Z80 współpracujący 

z mikrokomputerami zgodnymi z IBM PC/XT/AT, 
zastosowania: automatyka przemysłowa i telekomunikacja, 

• konwerter sygnałów standardu RS-232 - Centronics, 

• remonty mikrokomputerów, 

• podwyższanie jakości mikrokomputerów (zwiększame 
szybkości działania, niezawodności, funkcjonalności), 

• przystosowanie mikrokomputerów do pracy w systemach 
wielodostępnych (Xenix, Novell i inne), 

• połączenia mikrokomputerowe (PC-Odra, PC-Riad); 



# systemy wielodostępne (SCO Xenix 286, 386), 

• systemy sieciowe (Novell); 

Jeżeli jesteś autorem oryginalnego programu 
aplikacyjnego — skontaktuj się z nami, będziemy 
pośredniczyć w sprzedaży Twojego programu dbając 
o ochronę Twoich praw autorskich! 

”Medi - Tronik” Sp. z o.o. 

ul. Dzika 4,00-194 Warszawa 
tel. 635-22-63, 635-22-64, 635-23-37 
tbc 816075 medi pl 

Ko-49/241/02 
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najtańsze filtry ochronne 
do monitorów 12", 14" 
w ciągłej sprzedaży 
poleca TETA Sp. z o.o 
Przedsiębiorstwo Innowacyjne 

ul. Tenisowa 2C (obok PRiTV) WROCŁAW tel. (0 71) 67 58 25 


Ko-91 



ATM 

Przedsiębiorstwo 
Produkcyjno - Usługowe 
Warszawa ul. 
Grochowska 111/113 
tel.610-61-15 


- Oferuje: 

MULTIPLEKSER ATM MUX 4 

umożliwiający jednoczesną współpracę wielu komputerów z 

jedną drukarką 

KUPUJĄC MUL TłPLEKSER OSZCZĘDZASZ MILIONY 

-Opracowuje i wykonuje: 

specjalistyczne urządzenia mikroprocesorowe, informatyczne 
systemy zbierania i analizy danych, programy użytkowe. 

- Dostarcza: 

komputery klasy PC wraz z peryferiami i oprogramowaniem 

w dowolnej konfiguracji. 

NA ŻYCZENIE KLIENTÓW DOSTARCZAMY 
SZCZEGÓŁOWYCH INFORMACJI 

Ko-252 


Ogłoszenia przyjmuje Biuro Ogłoszeń, ul. Poznańska 38, 00-689 Warszawa, tel. 288641 



(D 


dent - service 


oferuje swoje usługi w zakresie: 

napraw pakietów i peryferii do komputerów kompatybilnych 
z IBM PC WAT 

objęcia gwarancją ww. komputerów i peryferii 
sprzedawanych przez przedsiębiorstwa nie posiadające 
własnego serwisu 
objęcia serwisem ww. sprzętu. 

Warszawa ul. J. Dąbrowskiego 3/14 

tel. 45-12-85 


Ko-268 


Nowe (nie regenerowane) tasiemki do drukarek 

komputerowych 

do nabycia w przedsiębiorstwie YES 
80—207 Gdańsk Al. Zwycięstwa 50 tel. 32-39-91 

’ ^ Ko-262 


Ekspressowa sprzedaż twardych dysków SEAGATE 

ze składu celnego. 

Warszawa, ul. Lenartowicza 15, tel. 44-05-14 

Ko-261 


AMIGA - COMMODORE 
SPRZEDAM 

Kielce tel. 28-767 po 16 


ATARI - ST 
TANIO SPRZEDAM 
Warszawa tel. 23-43-32 do 20-ej 


Ko-257 


Ko-260 
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• 44-100 GLIWICE 

i 5 5 ul. Bankowa 12 

Q 316640 tlx 036305 

- współpracujące z komputerem IBM po łączu szeregowym RS-232C 

- pracujące w czasie rzeczywistym dzięki sprzętowej kontroli pracy systemu uruchamianego 

- umożliwiające śladowanie wykonywanego programu 

- pracujące z zegarami wewnętrznymi lub zewnętrznymi Z80B - max 6MHz, 180 - max 2.5 MHz, 148 - max 6MHz 

- połączone z systemem uruchamianym za pośrednictwem sondy o długości 30 cm 

Turbo emulatory pozwalają na: 

- pracę Z możliwością ustawienia pułapek na: 

adres rozkazu, odwołanie do pamięci lub urządzeń we/wy, cykl przerwania i inne 

- pracę po cyklu maszynowym 

- pracę po cyklu rozkazowym 

- przeglądanie i zmianę zawartości rejestrów mikroprocesora, pamięci i urządzeń we/wy 

- testy pamięci systemu uruchamianego 

- disasemblację zawartości pamięci 

- asemblację liniową 

- emulację pamięci w blokach do 32 KB 

- pełne równoległe śladowanie magistral: 

adresowej, danych, sterującej mikroprocesora oraz dowolnych ośmiu sygnałów zewnętrznych w 2 KB pamięci śladów wyzwalanej 
w trybach NT, PRT, PST i CT 

Oprogramowanie oprócz obsługi turbo emulatora umożliwia: 

- edycję 

- asemblację 

- konsolidację 

- współpracę z programatorem pamięci EPROM 

Intech dostarcza również pełne systemy uruchomeniowe: 

- IBM PC XT/AT w dowolnej konfiguracji 

- Turbo emulator 

- programator pamięci EPROM 2716 - 27512 

- kasownik pamięęi EPROM 

- dokumentację oprogramowania 

Przy zakupie pełnych zestawów Intech udziela 10% rabatu 
Przedsiębiorstwo Wdrażania Postępu Technicznego “MKS - intech 
44-100 Gii wice ui. Bankowa 12 skr. poczt. 510^16640tix036305 
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Ko-261 
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Od niedawna powstają w naszym kraju łączone polsko-zagraniczne 
przedsiębiorstwa handlu komputerami. Przedsiębiorstwo takie 
sprowadza od partnera z zagranicy poszukiwany na rynku sprzęt J 
sprzedaje go swoim klientom. Za towar klient płaci przelewem na konto 
zagranicznego partnera. Potwierdzony przez bank dokument o doko¬ 
nanym przesłaniu pieniędzy jest podstawą do odbioru towaru. W 
sprzyjających warur\kach transakcja taka trwa jeden dzień. Jak uczą 
zaistniałe przypadki, taki obrót towarowy jest znacznie pewniejszy od 
lokowania pieniędzy w firmach wysyłkowych, gdzie termin odebrania 
przesyłki jest tylko domniemany. 

Jedna z bliskich ml osób, wykorzystująca prywatny komputer do 
codziennej pracy, postanowiła skorzystać z takiej formy uzupełnienia 
konfiguracji wykorzystywanego przez siebie narzędzia. Procedura 
zakupu wyglądała następująco. Na początek telefon do składu 
konsygnacyjnego z pytaniem czy dane zawarte w ogłoszeniu są 
prawdziwe. Odpowiedź była pozytywna ale sprzętu w magazynie 
jeszcze nie było. nie dotarł od producenta. Po kilkunastu dniach 
okazało się, ie sprzęt dotarł i może być zakupiony. Drugi etap to 
Informacja o cenach I formie płatności. Ceny podano,, telefonicznie 
biorąc je z aktualnego cennika. Teraz klient udał się do banku i po 
godzinie stania w kolejce dokonał przelewu na wskazane konto 
określonej wcześniej sumy. Z podstemplowanym i podpisanym po¬ 
świadczeniem dpkonanej wpłaty udał się do firmy prowadzącej skład 
konsygnacyjny. W siedzibie firmy okazało się, że sprzęt jest ale na 
lotnisku i nie jest dostępny dla nikogo. Trzeba zaczekać na załatwienie 
wszystkich formalności. Po dwóch dniach w telefonicznej rozmowie z 
przedstawicielem firmy klient dowiaduje się, że sprzęt owszem już jest 
ale ceny się zmieniły i dziś trzeba dopłacić aby transakcja mogła dojść 
do skutku. Ponieważ dopłata nie była bardzo wysoka a klientowi 
zależało na poszerzeniu konfiguracji komputera, więc dokonał dopłaty 
tego samego dnia. Dnia następnego udał się do firmy aby odebrać 
zakupiony towar. I teraz nowa niespodzianka. Oprócz w jakiś sposób 
zrozumiałych opłat za' przegląd zerowy i ewentualne roszczenia 
gwarancyjne, konieczne okazało się zapłacenie cła. Jak wszystkim 
zainteresowanym komputerami wiadomo sprzęt tego typu dla osób 
prywatnych ^olniony jest od opłat celnych. Kupując jednak komputer 
lub jego części w składzie konsygnacyjnym osoba prywatna płaci cło 
wynoszące około 160 zł za 1 dolar wartości sprzętu (tak było w 
opisywanej sprawie). Tak jest, tłumaczył przedstawIcleMIrmy, ponieważ 
przedsiębiorstwa prowadzące składy pracUią w tak zwanym obrocie 
handlowym. Nazewnictwo to nic ml nie mówi, a płacić trzeba. Klient 
zapłacił cło I inne opłaty i szczęśliwie zamontował w swoim komputerze 
zakupione elementy. 

Patrząc z boku na całą tę transakcję nasuwa się kilka uwag. Po 
pierwsze - zakup części ze składu konsygnacyjnego jest znacznie 
pewniejszy niż od firm wysyłkowych. Zakupu dokonuje się wtedy gdy 
poszukiwany przez nas towar jest na półce. Po drugie - firmy 
prowadzące taką działalność nie przejawiają ŻADNEJ INICJATYWY aby 
przekzać potencjalnym klientom dokładnych Informacji o formie zakupu. 
Po trzecie - nagłe podnoszenie cen i żądanie dopłat do zrealizowanych 
przelewów podważa wiarygodność i autorytet firmy. Po czwarte - 
niezrozumiałe jest działanie Urzędu Celnego w obsłudze osób 
prywatnych zakupujących sprzęt komputerowy. Inne przepisy dotyczą tej 
samej osoby stojącej z tym samym urządzeniem za te same pieniądze 
(czytaj z własnego legalnego konta bankowego) na granicy lub w 
punkcie spedycji a inne gdy odbioru dokonuje od pośrednika (właściciel 
składu konsygnacyjnego). 

W “handlową" sobotę udałem się do kilku sklepów aby sprawdzić 
czy nasz rynek haniowy oferuje swoim klientom sprzęt komputerowy. 
Okazuje się, że sieć uspołecznionego handlu oferuje taki sprzęt. 
Komputery I Ich wyposażenie można nabyć: w komisach, w placówkach 
Centralnej Składnicy Harcerkłej, w placówkach skupu I sprzedaży, 
towarów przemysłowych, w Pewexie I w Baltonie. Z danych jakie 
zebrałem w ten upalny dzień wynika, że najciekawszą ofertę posiada 
Centralna Składnica Harcerska, następnie punkty skupu i sprzedaży 
dalej komisy, Pewex I Baltona. Celowo nie wspominam tu o giełdach 
komputerowych gdyż z nimi konkurencji nie ma. Sprzęt sprzedawany 
przez CSH, Pewex i Baltonę ma zapewniony serwis gwarancyjny. Ceny 
w sprzedaży komisowej wysokie, uwzględniające konieczność pono¬ 
szenia opłat podatkowych przez sprzedającego. Małe zainteresowanie 
osób prywatnych, które wolą odwiedzać giełdy lub bazary. 

Dalej jak zwykle cennik z oferty CSH, komisów I Pewexu. 

Komputer Toshiba ^QOO XT - klasy IBM PC, przenośny, 

zasilany bateryjnie, z ciekłokrystalicznym ekranem, 

procesor 8088, wbudowana stacją dyskietek 

3,5 calowych, 640 KB RAM " 6600 tys. zł 


o 


klawiatura, bez monitora 

Komputer XPress 16 - procesor 8086/8 MHz, 

512 KB RAM, dwie stacje dyskietek 5,25 cala 

9400 tys. zł 

360 KB, klawiatura, bez monitora 

1600 tys. zł 

Monitor kolorowy EGA 14 cali 

1490 tys. zł 

Monitor mono dla karty Hercules 12 cali 

270 tys. zł 

Monitor mono dla karty Hercules 14 cali 
Programator EPROM z kartą i oprogramowaniem 

450 tys. zł 

dla PC/XT 

400 tys. zł 

Klawiatura PC/XT/AT 

2301^. zł 

Koprocesor matematyczny 80287/10 dla PC/AT 

19001^. zł 

Karta sieciowa D-Unk z oprogramowaniem 

715 tys. zł 

Drukarka Seikosha GP 500 

4951^. zł 

Drukarka Star NR-10 

2500 tys. zł 

Drukarka Star Radix 10 

10321^. zł 

Fax firmy Murata 

Casio komputerowa maszyna do pisania 

4978 tys. zł 

z pamięcią 1 strony tekstu 

RItr ochronny na ekran monitora 

1700 tys. zł 

mono 

40 tys. zł 

kolor 

Kasety z taśma do drukarek: 

55 tys. zł 

Star NL-10 

29 ^'S. zł 

NX-15 

391^. zł 

SG/10/15 

101^. zł 

Seikosha GP-50 

Dyskietki 5,25 cala: 

191^. zł 

DS/DD za sztukę 

4 tys. zł 

HD za sztukę 

Dyskietki 3,5 cala: 

91^. zł 

jednostronne 

7 tys. zł 

dwustronne 

91^. zł 

Kabel do drukarki ze złączem typu RS 

3,71^. zł 

Kabel do drukarki ze złączem Centronics 

Stacja dyskietek 3 calowych i kontrolerem 
do komputera ZX Spectrum/Timex 

391^. zł 

z jednym napędem 

450 tys. zł 

z dwoma napędami 

560 tys. zł 

Stacja dla dyskietek 5,25 cala do komputrów MSX 
Interfejs drukarki typu Centronics do 

6051^. zł 

komputera ZX Spectrum 

Interfejs joysticka typu Kempston do 

44,9 tys. zł 

komputera ZX Spectrum 

9,3 tys. zł 

Joybali (inny typ joysticka) do komputera MSX 

901^. zł 

Pudełko na 10 ztuk dyskietek 5,25 cala 

Ceny oprogramowania: 

11^. zł 

Kompilator Turbo Pascal wer. 4.0 dla PC/XT/AT 
interpreter Logo w kasecie pamięci ROM 

30 tys. zł 

dla komputera MSX 

Emulator terminala VT-52 w kasecie ROM 

100 tys. zł 

dla komputera MSX 

Zestawy gier na kasecie z taśmą 

100 tys. zł 

dla komputera ZX Spectrum 

2 - 3,5 tys. zł 

Zestawy gier na kasecie z taśmą 

• 

dla komputera Atari XL, XE 

Ceny w Pewexle: 

5,3 - 6,9 tys. zł 

przy nieobecności komputerów Atari 65 XE popularnością cieszy się 

zestaw Atari XE \Aćeo Gamę. Zestaw zawiera komputer Atari 65 XE z 

przystawką z trzema grami i pistoletem do celowania w ekran 
telewizora. Cena zestawu 159 bonów PKO 

Stacja dyskietek do komputera Atari XL, XE 

LDW2000 

189 bonów PKO 

Monitor mono SM 124 do komputera Atari ST 

175 bonów PKO 

Monitor kolorowy SCI 224 do komputera Atari ST 
Komputer Atari 520 STFM 512 KB RAM, 

410 bonów PKO 

wbudowana dwustronna stacja dyskietek 3,5 cala 

565 bonów PKO 

Dyskietki 5,25 cala za sztukę 

1 bon PKO 

D^kietki 3,5cala za sztukę 

2,4 bona PKO 

Taśma do drukarki Atari 1029 

6 bonów PKO 





















































































































































